一直不清楚对象的初始化过程,今天正好学了debug,就实验了一下,看代码一步一步执行感觉好舒服。
总结如下
- 父类静态变量
- 父类静态代码块
- 子类静态变量
- 子类静态代码块
- 主函数
- 父类显示初始化
- 父类的构造代码块
- 父类构造函数
- 子类显示初始化
- 子类构造代码块
- 子类构造函数
代码验证部分
public class Demo {
public static void main(String[] args) {
Demo2 d = new Demo2();
}
}
class Demo1 {
private static int s1=45;
int x=10;
//静态代码块
static{
System.out.println("父类静态代码块");
System.out.println(s1);
}
{
System.out.println("构造代码块");
System.out.println(x);
}
Demo1(){
super();
System.out.println("父类初始化"+x);
}
}
class Demo2 extends Demo1{
private static int s2=45;
private int y=23;
static {
System.out.println("子类静态代码块");
}
{
System.out.println("构造代码块");
System.out.println(x);
}
Demo2(){
super();
System.out.println("子类初始化");
System.out.println(y+"---"+x);
}
}
一静态部分
执行第7行,父类静态变量赋值。
执行第11行,静态代码块部分。
执行第24行,子类静态变量赋值。
执行第27行,子类静态代码块。
主函数
回到第2行,主函数args参数
执行第三行,为d对象分配空间,所有实例 变量初始化为0,null……
构造函数
执行第33行,本类构造函数
执行第34行,调用父类构造函数
执行第18行,然后第19行调用父类Object的构造方法,(Object为根类,构造方法中不再有super();)
执行第8行,父类显示初始化
执行第14行,父类的构造代码块
执行第20行,父类构造函数
执行第25行,子类显示初始化
执行第29行,子类的构造代码块
执行第35行,子类构造函数
程序运行结果
父类静态代码块
45
子类静态代码块
构造代码块
10
父类初始化10
构造代码块
10
子类初始化
23—10
ok,基本就是这样了,下一次我再忘记就可以来看看了。