class B {
B() {
System.out.println("B");
go();
}
private int a=1;
public void go(){
System.out.println("a="+a);
}
}
public class A1 extends B {
A1() {
System.out.println("A1");
}
private int a=11;
public void go(){
System.out.println("a="+a);
}
public static void main(String[] args) {
new A1();
}
}
以上代码输出结果为:
B
a=0
A1
我当时以为是输出a=11,结果回来跑了一把代码后,发现为0,即:先执行A1这时只是申明变量,并没赋值,然后执行B(),这时获取到a是A1里的,但还是初始值0呢,所以输出0.
后来经资料官方的解释为:对类变量的初始化是在执行完其构造方法的第一行代码(即this或super)后才开始的。
以下代码可以证实:
class B {
B() {
final B b=this;
go();
new Thread() {
public void run() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
b.go();
}
}.start();
}
public void go(){
}
}
public class A1 extends B {
A1() {
System.out.println("aa");
go();
}
private int a=11;
public void go(){
System.out.println("a="+a);
}
public static void main(String[] args) {
new A1();
}
}
输出结果为:
a=0
aa
a=11//这个是23行输出的
a=11//这个是12行输出的,由于另起了线程,所以在输出的时候已经执行完了构造方法