首先引入一个问题:
子类在继承父类的时候,父类的静态区,非静态区,构造方法,子类的静态区,非静态区,构造方法的执行顺序是怎么样的。
写一个简单的demo来验证一下:
父类:
public class Father {
static{
System.out.println("这是父类静态区");
}
{
System.out.println("这是父类非静态区");
}
public Father(){
System.out.println("这是父类的构造方法");
}
}
子类:
public class Son extends Father{
static{
System.out.println("这是子类静态区");
}
{
System.out.println("这是子类非静态区");
}
public Son(){
System.out.println("这是子类的构造方法");
}
}
主类:
public class Main {
public static void main(String[] args) {
Son son = new Son();
}
}
运行结果是:
这是父类静态区
这是子类静态区
这是父类非静态区
这是父类的构造方法
这是子类非静态区
这是子类的构造方法
可以看到执行顺序:
父类静态区 -> 子类静态区 -> 父类非静态区 -> 父类构造方法 -> 子类非静态区 -> 子类构造方法
那么原理是什么呢?
1.在new Son的对象之前要装载Son这个对象,根据类的加载模式,首先要装载Son的父类Father,所以先完成父类和子类的静态动作。
2.装载完类的后就需要实例化Son这个对象,在实例化Son的对象时也要先实例化父类Father,所以先执行父类的非静态区和构造方法(成员实例化),再去执行子类的非静态区和构造方法。
本文通过一个简单的Java示例程序演示了在子类继承父类的过程中,父类与子类中静态区、非静态区及构造方法的执行顺序。首先加载并执行父类与子类的静态区代码,随后实例化过程中按父类非静态区、父类构造方法、子类非静态区、子类构造方法的顺序执行。
839

被折叠的 条评论
为什么被折叠?



