子父类中的构造方法的特点
1. 在子类构造对象时,发现访问子类构造方法时,父类也运行了.为什么呢?
答:因为,在子类构造方法中第一行有一个默认的隐式语句:super();
子类的实例化过程:子类中所有的构造方法默认都会访问父类中的空参的构造方法.
2.为什么子类实例化的时候要访问父类中的构造方法呢?
答:因为,在子类继承了父类,就获取到了父类中的内容,所以在使用父类内容之前,要先看父类是如何对自己的内容进行初始化的;所以子类在构造对象时,必须访问父类中的构造方法,为了完成这个必须的动作,就在子类构造方法中加入了super();语句. ps:如果父类中定义了构造有参构造,却没有定义无参构造,那么在子类构造方法中必须用super(参数列表)明确要调用的父类中的构造方法.
注意:super语句必须放在子类构造方法的第一行,因为父类的初始化动作要先完成.
创建子类对象时初始化过程:
首先在堆内存中开辟内存空间----->父类,子类默认初始化----->子类构造进栈----->执行第一行super()----->父类构造进栈
----->父类显示初始化----->父类构造代码块初始化----->父类构造方法初始化----->父类构造方法执行完毕----->回到子类构造
----->子类显式初始化----->子类构造代码块初始化----->子类构造方法初始化----->子类构造方法执行完毕----->初始化完成.
另外说一点:不管是在子类还是父类的方法中,如果默认有this的,那么这个this都指向子类对象,也就是说,在父类的方法中,如果有this的(也可以说是没有被static修饰的),都是指向了子类的对象所在的内存区域,而不是父类,因为这个时候就没有父类对象.
1. 在子类构造对象时,发现访问子类构造方法时,父类也运行了.为什么呢?
答:因为,在子类构造方法中第一行有一个默认的隐式语句:super();
子类的实例化过程:子类中所有的构造方法默认都会访问父类中的空参的构造方法.
2.为什么子类实例化的时候要访问父类中的构造方法呢?
答:因为,在子类继承了父类,就获取到了父类中的内容,所以在使用父类内容之前,要先看父类是如何对自己的内容进行初始化的;所以子类在构造对象时,必须访问父类中的构造方法,为了完成这个必须的动作,就在子类构造方法中加入了super();语句. ps:如果父类中定义了构造有参构造,却没有定义无参构造,那么在子类构造方法中必须用super(参数列表)明确要调用的父类中的构造方法.
注意:super语句必须放在子类构造方法的第一行,因为父类的初始化动作要先完成.
创建子类对象时初始化过程:
首先在堆内存中开辟内存空间----->父类,子类默认初始化----->子类构造进栈----->执行第一行super()----->父类构造进栈
----->父类显示初始化----->父类构造代码块初始化----->父类构造方法初始化----->父类构造方法执行完毕----->回到子类构造
----->子类显式初始化----->子类构造代码块初始化----->子类构造方法初始化----->子类构造方法执行完毕----->初始化完成.
另外说一点:不管是在子类还是父类的方法中,如果默认有this的,那么这个this都指向子类对象,也就是说,在父类的方法中,如果有this的(也可以说是没有被static修饰的),都是指向了子类的对象所在的内存区域,而不是父类,因为这个时候就没有父类对象.