java构造方法,以及super、this关键字、隐式调用、显式调用
2016-05-24 22:15
375 查看
首先需要明白的是,当创建java对象时,程序总是依次调用每个父类的非静态初始化块、父类构造器(总是从Object开始)执行初始化,最后才调用该类的非静态初始化块、构造器执行初始化。
如果你不明白初始化的本质,请看这篇博文http://blog.csdn.net/xuejingfu1/article/details/51480687。
为了说明问题,这里贴出一个小例子:
class Parent{
static{
System.out.println("父类静态初始化块");
}
{
System.out.println("父类非静态初始化块");
}
public Parent(){
System.out.println("父类无参构造器");
}
public Parent(String name){
System.out.println("父类含参构造器:name="+name);
}
}
public class Child extends Parent{
static{
System.out.println("子类静态初始化块");
}
{
System.out.println("子类非静态初始化块");
}
public Child() {
this("lily");
System.out.println("子类无参构造器");
}
public Child(String name){
super(name);
System.out.println("子类含参构造器: name="+name);
}
public static void main(String[] args) {
Child c1=new Child("Tom");
Child c2=new Child();
}
}
输出结果:
--------------------------------------------------------------------------------------
父类静态初始化块
子类静态初始化块
父类非静态初始化块
父类含参构造器:name=Tom
子类非静态初始化块
子类含参构造器: name=Tom
父类非静态初始化块
父类含参构造器:name=lily
子类非静态初始化块
子类含参构造器: name=lily
子类无参构造器
--------------------------------------------------------------------------------------
容易得到这样的结论:
无论新实例化多少个对象,该类的所有父类以及自身的静态初始化块只执行一次,而且是最先执行的初始化,称作类的初始化。之后的初始化会依次执行父类的非静态初始化块、父类的构造器和子类的非静态初始化块、子类的构造器来完成初始化称为对象初始化;在子类的构造器中可以通过super来显式调用父类的构造器,可以通过this来调用该类重载的其他构造器,而具体调用哪个构造器决定于调用时的参数类型。
super与this 进阶:
super用于该类显式调用父类构造器、this用于该类显式调用类中其他重载的某个构造器;如果一个构造器中没有super调用,则会隐式调用父类的无参构造器。super和this的调用只能在构造器中,而且都必须作为构造器中的第一行,因此super和this不会同时出现在同一个构造器中;
如果你不明白初始化的本质,请看这篇博文http://blog.csdn.net/xuejingfu1/article/details/51480687。
为了说明问题,这里贴出一个小例子:
class Parent{
static{
System.out.println("父类静态初始化块");
}
{
System.out.println("父类非静态初始化块");
}
public Parent(){
System.out.println("父类无参构造器");
}
public Parent(String name){
System.out.println("父类含参构造器:name="+name);
}
}
public class Child extends Parent{
static{
System.out.println("子类静态初始化块");
}
{
System.out.println("子类非静态初始化块");
}
public Child() {
this("lily");
System.out.println("子类无参构造器");
}
public Child(String name){
super(name);
System.out.println("子类含参构造器: name="+name);
}
public static void main(String[] args) {
Child c1=new Child("Tom");
Child c2=new Child();
}
}
输出结果:
--------------------------------------------------------------------------------------
父类静态初始化块
子类静态初始化块
父类非静态初始化块
父类含参构造器:name=Tom
子类非静态初始化块
子类含参构造器: name=Tom
父类非静态初始化块
父类含参构造器:name=lily
子类非静态初始化块
子类含参构造器: name=lily
子类无参构造器
--------------------------------------------------------------------------------------
容易得到这样的结论:
无论新实例化多少个对象,该类的所有父类以及自身的静态初始化块只执行一次,而且是最先执行的初始化,称作类的初始化。之后的初始化会依次执行父类的非静态初始化块、父类的构造器和子类的非静态初始化块、子类的构造器来完成初始化称为对象初始化;在子类的构造器中可以通过super来显式调用父类的构造器,可以通过this来调用该类重载的其他构造器,而具体调用哪个构造器决定于调用时的参数类型。
super与this 进阶:
super用于该类显式调用父类构造器、this用于该类显式调用类中其他重载的某个构造器;如果一个构造器中没有super调用,则会隐式调用父类的无参构造器。super和this的调用只能在构造器中,而且都必须作为构造器中的第一行,因此super和this不会同时出现在同一个构造器中;
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- Python动态类型的学习---引用的理解
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序