java中第一次实例化一个对象时,静态代码块、初始化块、属性的初始化、构造方法,再加上如果父类也有这些东西,天,到底执行顺序是什么?
来一段代码试一试就知道了:
public class LoadingTest {
public static void main(String[] args) {
new TestLoading();
}
}
class TestLoading extends SuperTestLoading {
private static Integer i = getIntegerI();
private Integer j = getIntegerJ();
static {
System.out.println("子类的静态代码块");
}
{
System.out.println("子类的初始化代码块");
}
TestLoading() {
System.out.println("子类的构造方法");
}
private static Integer getIntegerI() {
System.out.println("子类的静态属性");
return null;
}
private static Integer getIntegerJ() {
System.out.println("子类的实例属性");
return null;
}
}
class SuperTestLoading {
protected static Integer superI = getIntegerI();
protected Integer superJ = getIntegerJ();
static {
System.out.println("父类的静态代码块");
}
{
System.out.println("父类的初始化代码块");
}
SuperTestLoading() {
System.out.println("父类的构造方法");
}
private static Integer getIntegerI() {
System.out.println("父类的静态属性");
return null;
}
private static Integer getIntegerJ() {
System.out.println("父类的实例属性");
return null;
}
}
之后我自己再通过反复交换代码所在的位置,得出以下执行顺序:
父类的静态代码块、父类的静态属性——>子类的静态代码块、子类的静态属性——>父类的初始化代码块、父类的实例属性——>父类的构造方法——>子类的初始化代码块、子类的实例属性——>子类的构造方法。
其中顺序从前到后,其中用"、"号分隔的两个都是优先级相同的,谁先执行看代码在类中的位置,靠上的先执行。
基本原则就是:静态的早于实例的、父类的早于子类的、构造方法最晚。