为什么子类的构造器中要调用父类的无参构造方法,有什么意义?

当一个子类调用构造方法时,我们知道它都会调用父类隐性的构造方法,如图:

但是,我发现一个问题,为什么要这样设计,为什么子类一定要调用到父类的无参构造方法,或者你可以选择调用其他有参的父类构造方法,这可能跟子类实例化的时候也要先加载父类的构造代码块,静态代码块一个缘由。于是我查了很多资料发现,大概都是同一个意思:因为子类继承父类之后,获取到了父类的内容(属性/字段),而这些内容在使用之前必须先初始化,所以必须先调用父类的构造函数进行内容的初始化.

同时我看到论坛有一个回复:

我得出的结论是:这是java的一种规范,告诉我们如果子类实例化,那就需要先初始化父类的变量,例如私有的成员变量(通过父类构造方法),子类才不需要自己去实例化分类的变量。

 

 

参考资料:

https://blog.csdn.net/PoorGuy_tn/article/details/79854846

https://blog.csdn.net/qq_34787830/article/details/52194200

https://www.cnblogs.com/alsf/p/9286821.html

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值