weixin_43113933 2020-05-10 11:26 采纳率: 58.3%
浏览 337
已采纳

一个强迫症患者关于c++子类构造函数调用父类构造的问题?

c++中子类对象创建时,如果父类包含有有参构造函数,则必须在子类构造函数的初始化列表中
初始化,可是为什么必须要这样做,我知道是为了初始化子类继承父类的成员变量。java中是在子类构造函数的
第一行显示调用父类有参构造初始化,我想问的是c++必须在子类构造函数的初始化列表中进行
初始化仅仅是语法的规定么。比如:c++也可以在子类构造函数第一行调用父类构造函数初始化啊
,有没有其它更好的解释

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-05-10 13:12
    关注

    语法这么规定的,因为构造派生类要调用基类构造函数,当基类默认无参构造函数不存在,或者多个构造函数的情况下,那么调用哪个必须要可以预期,由程序员来控制。
    所以必须引入这样的语法。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 9月25日