C++为什么父类析构函数要定义为虚析构函数

本文详细解释了C++中为什么父类析构函数需要定义为虚析构函数,主要涉及构造函数和析构函数的调用规则。通过实例展示了在多态情况下,非虚析构函数可能导致的内存泄漏问题,强调了虚析构函数在对象销毁过程中的关键作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++为什么父类析构函数要定义为虚析构函数

这个问题主要是由于子类继承父类时,构造函数和析构函数的调用问题产生的结果:
第一点我们需要知道,子类在继承时构造函数是不能被继承的。但是,为了初始化从父类继承来的数据成员,系统需要调用其父类的构造方法。因此必定会调用父类的构造函数。

构造原则:

如果子类没有定义构造方法,则调用父类的无参数的构造方法。
如果子类定义了构造方法,不论是无参数还是带参数,在创建子类的对象的时候,首先执行父类无参数的构造方法,然后执行自己的构造方法。
在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数,则会调用父类的默认无参构造函数。
在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类自己提供了无参构造函数,则会调用父类自己的无参构造函数。
在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类只定义了自己的有参构造函数,则会出错(如果父类只有有参数的构造方法,则子类必须显示调用此带参构造方法)。
如果子类调用父类带参数的构造方法,需要用初始化父类成员对象的方式

总结一点就是,只要使用子类来定义一个对象,就必定会调用父类的构造函数或者默认构造函数。

就是有蛋必有鸡,可能这个会有异议;换句话说就是想有儿子必有爹,想要有儿子,就必须要先把父亲的东西安置好。这个没办法反驳吧。hh

可能会有人纠结上面六种方法,那么我们先看下上面的六种方法:

不用看子类如何,父类可以分为两类,仅仅就是子类写构造函数的区别:</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值