案例代码:
class A{
public A()
{
System.out.println("1.父类A的构造方法");
}
{
System.out.println("2.父类A的构造代码块");
}
static{
System.out.println("3.父类A的静态代码块");
}
}
public class B extends A{
public B()
{
System.out.println("4.子类B的构造方法");
}
{
System.out.println("5.子类B的构造代码块");
}
static{
System.out.println("6.子类B的静态代码块");
}
//测试
public static void main(String[] args)
{
System.out.println("7.start......");
new B();
System.out.println("8.end.....");
}
}
输出结果:
>>> 3.父类A的静态代码块
>>> 6.子类B的静态代码块
>>> 7.start......
>>> 2.父类A的构造代码块
>>> 1.父类A的构造方法
>>> 5.子类B的构造代码块
>>> 4.子类B的构造方法
>>> 8.end.....
-
主类B中的静态块优先于主方法执行,所以6应该在7前面执行,且B类继承于A类,所以先执行A类的静态块3,所以进入主方法前的执行顺序为:3 6
-
进入主方法后执行7,
new B()
之后应先执行A的构造方法然后执行B的构造方法,但由于A类和B类均有构造代码块块,构造代码块又优先于构造方法执行即 2 1(A的构造家族) 5 4(B的构造家族),有多少个对象,构造家族就执行几次,题目中有两个对象 所以执行顺序为:3 6 7 2 1 5 4 2 1 5 4 8
这里有个更具体的案例:一道有意思的“初始化”面试题