1.运行下面代码,输出的结果是(A)
class A {
public A() {
System.out.println("class A");
}
{ System.out.println("I'm A class"); }
static { System.out.println("class A static"); }
}
public class B extends A {
public B() {
System.out.println("class B");
}
{ System.out.println("I'm B class"); }
static { System.out.println("class B static"); }
public static void main(String[] args) {
new B();
}
}
A . class A static
class B static
I’m A class
class A
I’m B class
class B
B . class A static
I’m A class
class A
class B static
I’m B class
class B
C . class A static
class B static
class A
I’m A class
class B
I’m B class
D . class A static
class A
I’m A class
class B static
class B
I’m B class
解析:
Java程序初始化的执行顺序:
父类静态变量—>父类静态代码块—>子类静态变量—>子类静态代码块—>父类非静态变量—>
父类非静态代码块—>父类构造方法—>子类非静态变量—>子类非静态代码块—>子类构造方法
2.下列说法正确的是(AB)
A.对于局部内部类,只有在方法的局部变量被标记为final或局部变量是effctively final的,内部类才能使用它们
B.成员内部类位于外部类内部,可以直接调用外部类的所有方法(静态方法和非静态方法)
C.由于匿名内部类只能用在方法内部,所以匿名内部类的用法与局部内部类是一致的
D.静态内部类可以访问外部类的成员变量
解析:首先,外部类和内部类是处于同一个级别的,内部类不会因为定义在方法中就随着方法执行完毕而被销毁。那么问题来了,如果外部类的方法中变量不定义为final,那么外部类的方法执行完毕后,这个局部变量肯定被gc了。这时候内部类的某个方法还没执行完,却找不到他引用的外部变量了。
如果定义为final,Java就会将这个变量复制一份作为成员变量置于内部类中,这样的话,final修饰的值始终无法改变,所以这个变量所指向的内存区域就不会变。
本文详细解析了Java程序初始化的执行顺序,包括父类和子类的静态及非静态变量、代码块和构造方法的执行流程。同时,深入讨论了局部内部类、成员内部类、匿名内部类和静态内部类的特性与使用限制。
817

被折叠的 条评论
为什么被折叠?



