举个基本的例子来说明类初始化的顺序:
public class MyMain {
public static void main(String args[]) {
Father f = new Son();
}
}
class Father {
static int a = 1;
//static Father father = new Father(); //如果打开注释,执行时将此代码放到下面的static块中
static {
System.out.println("print in father");
}
public Father() {
System.out.println("Father Construct");
}
}
class Son extends Father {
static int b=1;
//static Son son = new Son();
static {
System.out.println("print in son");
}
public Son() {
System.out.println("Son Construct");
}
}
上面例子的执行结果为:
print in father
print in son
Father Construct
Son Construct
从结果看到执行顺序为:父类静态属性--父类静态代码块--子类静态属性--子类静态代码块--父类构造函数--子类构造函数
但是如果把注释打开,也就是类中包含自身的属性,且为静态的,这样执行结果为:
Father Construct
print in father
Father Construct
Son Construct
print in son
Father Construct
Son Construct
从结果中可以看到执行顺序为:父类静态属性--父类构造函数--父类静态代码块--子类静态属性--子类构造函数--子类静态代码块--父类构造函数--子类构造函数
分析:从上的例子可以看出,如果类中有自身对象且为静态的,限制性构造函数,并不是一味的先执行静态的属性,构成递归。
如果去属性的static,那么这样就构成递归了,可以用上面的里试一下就看到结果了。