问题:类变量、成员变量、静态代码块、非静态代码块在父类和子类的初始化和执行状况
代码如下:
package ss;
//父类
class Test4{
private int x;
private static int y ;
static{
y = 4;
System.out.println("父类的静态代码块:y="+y);
}
{
x = 3;
System.out.println("父类的非静态代码块:x="+x);
}
Test4(){
System.out.println("父类的默认构造方法");
}
}
//子类
public class Test3 extends Test4{
private int m;
private static int n;
static{
n = 4;
System.out.println("子类的静态代码块:n="+n);
}
{
m = 3;
System.out.println("子类的非静态代码块:m="+m);
}
Test3(){
System.out.println("子类的默认构造函数");
}
public static void main(String[] args){
new Test3();
}
}
输出结果:
分析:编译器在编译阶段,针对每个class文件会生成“类构造器”和“实例化构造器”
包括:类变量赋值动作、静态代码块(从类中收集,并组成一个新的方法。由jvm在加载的时候执行)
包括:调用父类的init、成员变量的赋值动作、非静态代码块、构造函数代码(由程序员通过new对象的时候等触发)
方法的执行顺序:父类的clinit()、子类的cinit()、父类的init()、子类的init()
内部细致的执行顺序划分:父类的类变量的赋值动作、父类的静态代码块、子类的类变量的赋值动作、子类的静态代码块、父类的成员变量的赋值动作、父类的非静态代码块、父类的默认构造方法、子类的成员变量的赋值动作、子类的非静态代码块、子类的默认构造方法