#include<iostream>
#include<string>
using namespace std;
struct B
{
string b;
~B(){cout<<"~B....."<<endl;}
};
struct D : B
{
string d;
~D(){cout<<"~D...."<<endl;}
};
int main()
{
B *pb = new D;
delete pb;
return 0;
}
运行的结果为:
很明显,“delete pb;”只调用了 B 的析构函数,没有调用 D 的析构函数,从而导致内存的遗漏。
这个问题涉及“虚析构函数”,不知道你们学没。当基类对象的指针或引用调用派生类对象时,如果基类的析构函数不是虚析构函数,则通过基类指针或引用对派生类的析构是不彻底的!解决这个问题其实很简单,只要在struct B 中添加的析构函数加一个“virtual”关键字就行了
虚析构函数
最新推荐文章于 2023-10-29 21:05:56 发布