初始化过程是这样的:
1.首先,初始化父类中的静态成员变量和静态代码块,按照在程序中出现的顺序初始化;
2.然后,初始化子类中的静态成员变量和静态代码块,按照在程序中出现的顺序初始化;
3.其次,初始化父类的普通成员变量和代码块,在执行父类的构造方法;
4.最后,初始化子类的普通成员变量和代码块,在执行子类的构造方法;
以上是一般过程,首先一开始先初始化的是静态成员变量和静态代码块是因为这些代码在累加载的时候就加载进内存了,已经执行过一遍了(这个相信大家都是知道,就不再演示了),类中的其他代码块是在对象建立的时候才会去执行,比如构造函数。
新建子类的时候,先假设么没有静态变量等,执行过程:父类的默认构造方法->子类的构造方法;但是如果在子类的构造方法中明确调用父类的哪个构造方法,那么执行结果是不一样的。例如
class A {
A() {
this("A");
System.out.print("A");
}
A(String s) {
System.out.print(s);
}
}
1
class Test extends A {
Test() {
super("B");//显示调用的父类的构造方法方法
System.out.print("B");
}
}
2
class Test extends A {
Test() {
super();//调用的父类方法和上面一种是不一样的,而且就算在这边不写super(),默认也会调用super(),不信你试试
System.out.print("B");
}
}
此外,希望大家明白以下两句话中红色字是什么意思:
3.其次,初始化父类的普通成员变量和代码块,在执行父类的构造方法;
4.最后,初始化子类的普通成员变量和代码块,在执行子类的构造方法;
举个例子:
class C {
C() {
System.out.print("C");
}
}
class A {
C c = new C();
A() {
System.out.print("A");
}
A(String s) {
System.out.print(s);
}
public static void main(String[] args) {
new A();
}
}
执行结果如下:
CA
看见木有,是先执行C c = new C();再执行A的构造函数的哦