接着上一章节。
(4)无参构造器初始化
这里我们来聊聊初始化的话题,特别是初始化基类,父类会怎样?
继续沿用上面的代码,我们做出一些精简。
package com.ray.testobject;public class Test {public static void main(String[] args) {new Sub();}
}class Father {public Father() {System.out.println("create father");}
}class Sub extends Father {public Sub() {System.out.println("create Sub");}
}
输出:
create father
create Sub
为什么?
其实,在编译的过程中,编译器已经为我们在子类里面new一个隐藏的父类,所以就会出现我们虽然只是new子类,但是父类也同时new。
而且有一点需要注意的是,父类是在子类之前就已经new出来的。
对于执行顺序这个东西,我们再来一个实验,因为说到顺序这个,我们就必须引进静态代码块,因为这个也是关键
package com.ray.testobject;public class Test {public static void main(String[] args) {new Sub();}
}class Father {private static int id;static {System.out.println("id:" + id);System.out.println("a");}public Father() {System.out.println("create father");}
}class Sub extends Father {private static String name;static {System.out.println("name:" + name);System.out.println("b");}public Sub() {System.out.println("create Sub");}
}
输出:
id:0
a
name:null
b
create father
create Sub
从输出结果可以看见执行顺序:
1.静态属性域
2.静态代码块
3.父类构造器
4.子类构造器
(5)有参构造器初始化
上面已经讨论了无参的情况,我们下面来聊一下有参的情况。
注意点:
1.子类必须具有相关参数的构造器
2.构造器必须引用super(父类)的构造器
package com.ray.testobject;public class Test {public static void main(String[] args) {}
}class Father {public Father(int id) {System.out.println("create father");}
}class Sub extends Father {public Sub(int id) {super(id);// 如果没有这一句,报错,找不到父类相关的构造器。System.out.println("create Sub");}public Sub(int id, String name) {super(id);// 如果没有这一句,报错,找不到父类相关的构造器。System.out.println("create Sub");}
}
就像sub的两个构造器,只要有相关的参数id(有其他参数也无所谓),而且构造器必须调用super()。
总结:这一章节主要讨论了有参和无参的构造器初始化情况。
这一章节就到这里,谢谢。
-----------------------------------
目录