3/01/2006

从Java嵌套类中访问外部类成员

在下面,我们看到对于B类来说他的嵌套层次是:AcessMethod-〉A-〉B,那么访问方法如下:

class B {
 void h() {
  System.out.println("h()");
  g();
  f();
}

AcessMethod和A来说对B,都是透明的,直接调用。嵌套类实例化的顺序:有外到里!AcessMethod-〉A-〉B

  调用代码如下:
AcessMethod am = new AcessMethod();
AcessMethod.A a = am.new A();
AcessMethod.A.B b = a.new B();
b.h();

这里很有意思的一点,’.new’语法产生了正确的作用域。

  疑问:下面我们来看一下在B.h()中怎样调用A1.g()方法?

  我们是否可以在B中调用A1.g()方法,在B.h()方法中原则上可以这样调用A1.g()但是A1没有实例化,所以这样是错误的,也就是在B中无法调用A1中的非静态方法了。

  假设:如果A1.g()为static类型,那么在B中可以这样调用A1种的方法:A1.this.g();

  但是这是不可能的,因为在A1.g()不可能定义为static类型,详细看下面的问题1(问题1:在什么情况下可以定义static 方法),这是一个缺点吧,但是可以使用嵌套类来解决了。

/**
* 从多层嵌套类中访问外部类的成员. “.new“语法产生了正确的作用域
*/
public class AcessMethod {

 private void f() {
  System.out.println("f()");
 }


 class A1 {
  private void g() {
   System.out.println("A1 - g()");
  }
 }

 class A {
  private void g() {
   System.out.println("g()");
  }

  class B {
   void h() {
    System.out.println("h()");
    g();
    f();
   }
  }
 }

 public static void main(String[] args) {
  AcessMethod am = new AcessMethod();
  AcessMethod.A a = am.new A();
  AcessMethod.A.B b = a.new B();
  b.h();
 }
}

运行结果:h()
g()

f()

问题1:在什么情况下可以定义static 方法?

  只有在顶层类中定义,或者在静态内部类中定义,看下面的例子

public class Test {
 static void t(){}
 class T2{
  //!错误,The method a cannot be declared static;
  //static methods can only be declared in a static or top level type
  //static void a(){}
 }

 static class T3{
  static void a(){}
 }
}

weblogic+mysql配置

在开发java的程序时,使用mysql+weblogic的环境配置,在配置过程中发现,网络上配置资源信息非常少,而且,错误连篇。特此给出正确的配置方法。
首先安装mysql、mysqlcc、weblogic等相应的软件,然后将mysql的驱动程序加入到weblogic中,例如我现在的系统中的weblogic版本weblogic8.12,安装位置在E:盘上,则正确的复制路径是E:\bea8.12\weblogic81\server\lib。
将jdbc驱动的路径加载到E:\bea8.12\user_projects\domains\mydomain\startWebLogic.cmd,其格式是这样的,
@REM Set SERVER_NAME to the name of the server you wish to start up.

set SERVER_NAME=myserver

set CLASSPATH=%WL_HOME%\server\lib\mysql-connector-java-3.1.4-beta-bin.jar;%WEBLOGIC_CLASSPATH%;% POINTBASE_CLASSPATH%;%JAVA_HOME%\jre\lib\rt.jar;%WL_HOME%\server\lib\webservices.jar;%CLASSPATH%

或者,我们采用一种更为简单有效的方法,在我的电脑中的环境变量的classpath中加入驱动所在的位置即可。

3. 在weblogic8.12中配置mysql的jdbc连接池

Name = MySQL Connection Pool
URL = jdbc:mysql://127.0.0.1:3306/ejbshop//数据库的名字
Driver classname = org.gjt.mm.mysql.Driver或者com.mysql.jdbc.Driver
Properties : user=root
password=root

数据源

Name = MySQL Tx Data Source
JNDI Name = MySQL
Pool Name = MySQL Connection Pool

附:更多相关内容察看mysql的帮助文档,