例如在这个问题中捕获了实例初始化的阶段。然而,它并没有捕捉到实例变量 get 被声明和自动初始化的时刻。
从下面的测试代码中,我可以看到 Child 类的实例变量 int "i" 甚至在 Child 类的实例初始化程序运行之前就可以访问。但是这个 i 变量是什么时候声明和自动初始化的呢?
代码
class Parent{
static{ System.out.println("Static Parent initialization"); }
int i=1234;
{ System.out.println("Parent's instance initializer running");
print("executed from Parent's instance initializer");
update(1);
}
Parent() {
System.out.println("Parent's constructor running");
print("executed from Parent's constructor");
update(2);
}
void print(String note) { System.out.println("never executed"); }
void update(int newI){ System.out.println("never executed"); }
}
class Child extends Parent{
static{ System.out.println("Static Child initialization"); }
int i = 3;
{System.out.println("Child's instance initializer; i=" + i); }
Child(){super(); i=4; System.out.println("Child's constructor running. Setting i to 4");}
void print(String note) { System.out.println("print(): '"+note.toUpperCase()+"' ; i="+i); }
void update(int newI){i=newI;System.out.println("update("+newI+"): After update i="+i);}
}
class Context {
public static void main(String[] args) {
Parent parent = new Child();
System.out.println("In main: child's i="+((Child)parent).i);
System.out.println("In main: parent's i=" +parent.i);
}
}
输出
静态父初始化
静态子初始化
父实例初始化程序运行
print(): '从父实例初始化器中执行' ; 我=0
更新(1):更新后 i=1
父母的构造函数运行
print(): '从父构造函数中执行' ; 我=1
更新(2):更新后 i=2
Child的实例初始化器;我=3
孩子的构造函数正在运行。将 i 设置为 4
主要:孩子的 i=4
主要是:父母的 i=1234