介绍
1.只有虚析构 (PS:没有虚构造)
2.加与不加 virtual关键词 的区别2.1如果父类的析构函数 不是虚析构,则父类指针指向子类时,delete掉父类的指针
(PS:则效果为 只调用父类的析构的函数,不调用子类的析构函数)
2.2 如果父类的析构函数 是虚析构,则父类的指针指向子类时,delete掉父类的指针
(PS:则效果为 先调用子类的析构函数,再调用父类的析构函数)
不加 virtual 的源码
在结果中可以看出,并没有执行 子类B 的析构步骤且 子类B 中申请了空间并没有delete掉,造成了内存泄漏
#include<iostream>
#include<string>
using namespace std;
class A
{
public:
A(){ cout << "A构造" << endl; }
~A(){ cout << "A析构" << endl; }
};
class B:public A
{
public:
B()
{
cout << "B构造" << endl;
p = new int(10);
}
~B()
{
cout << "B析构" << endl;
delete p;
}
private:
int*p;
};
void main()
{
{
//创建基类指针
A *p = new B;
delete p;
}
system("pause");
}
不加 virtual 的运行结果
A构造
B构造
A析构
请按任意键继续. . .
加 virtual 的源码
加了 virtual 的基类析构后,会形成虚析构。虚析构作用和虚函数作用类似。
#include<iostream>
#include<string>
using namespace std;
class A
{
public:
//构造函数
A(){ cout << "A构造" << endl; }
//虚析构函数
virtual ~A(){ cout << "A析构" << endl; }
};
class B:public A
{
public:
B()
{
cout << "B构造" << endl;
p = new int(10);
}
//这里会产生隐式转换成 虚析构函数
~B()
{
cout << "B析构" << endl;
delete p;
}
private:
int*p;
};
void main()
{
{
//创建基类指针
A *p = new B;
delete p;
}
system("pause");
}
加 virtual 的运行结果
A构造
B构造
B析构
A析构
请按任意键继续. . .