(C++)构造函数和析构函数中的虚函数

本文介绍了C++中构造派生类和析构时对象类型的不完整性,强调了虚函数在构造函数中的限制,并讨论了析构函数作为虚函数的重要性和内存泄漏风险。通过实例演示了为什么构造函数不能为虚函数,以及虚析构函数如何确保正确释放内存。
摘要由CSDN通过智能技术生成

原文引自《C++ Prime》中文版P497:

构造派生类对象时首先运行基类构造函数初始化对象的基类部分。在执行基类构造函数时,对象的派生类部分是未初始化的。实际上,此时对象还不是一个派生类对象。
撤销派生类对象时,首先撤销它的派生类部分,然后按照与构造顺序的逆序撤销它的基类部分。
在这两种情况下,运行构造函数或析构函数的时候,对象都是不完整的。为了适应这种不完整,编译器将对象的类型视为在构造或析构期间发生了变化。在基类构造函数或析构函数中,将派生类对象当作基类类型对象对待。

示例:

 class A {
	 A() { foo(); }
	 virtual ~A() { foo(); }
	 virtual void foo() { cout << "父类调用" << endl; }
	 void bar() { foo(); }
};
 class B :public A {
	 virtual void foo() { cout << "子类调用" << endl; }
 };

int main(){
	B b;
	b.bar();
}

输出:
在这里插入图片描述
C++不能将构造函数声明为虚函数
构造函数用来创建一个新的对象,而虚函数的运行是建立在对象的基础上,在构造函数执行时,对象尚未形成,所以不能将构造函数定义为虚函数。
可以将析构函数声明为虚函数防止内存泄漏
delete一个基类指针p时,如果析构函数为虚函数,则根据对象类型去析构对象。当p指向子类时先调用子类析构函数,再调用基类构造函数。
如果析构函数非虚,则只会根据指针类型调用基类析构函数,造成内存泄漏。

参考:
https://blog.csdn.net/weixin_30342827/article/details/95279077

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CET4_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值