C++分析如何用虛析構與純虛析構處理內(nèi)存泄漏
一、問題引入
使用多態(tài)時,如果有一些子類的成員開辟在堆區(qū),那么在父類執(zhí)行完畢釋放后,沒有辦法去釋放子類的內(nèi)存,這樣會導致內(nèi)存的泄漏。如下代碼段。
如果沒有堆區(qū)的數(shù)據(jù),可以不寫虛析構或純虛析構。
#include <iostream>
#include <string>
using namespace std;
class Animal{
public:
Animal(){
cout<<"Animal-構造"<<endl;
}
~Animal(){
cout<<"Animal-析構"<<endl;
}
virtual void Run()=0; //純虛函數(shù)無需實現(xiàn),只需聲明
};
class Cat:public Animal{
public:
string *s_name;
Cat(string name){
s_name = new string(name);//在堆區(qū)創(chuàng)建內(nèi)存
cout<<"Cat-構造"<<endl;
}
void Run()
{
cout<<*s_name<<"->"<<"Cat-Run"<<endl;
}
~Cat(){
cout<<"Cat-析構"<<endl;
if(s_name!=NULL){
delete s_name;
s_name=NULL;
}
}
};
int main()
{
Animal *a;
a = new Cat("Tom");
a->Run();
delete a; //父類指針析構的時候,不會調用子類析構函數(shù)
return 0;
}運行結果:

結果可以看到都有父類和子類的構造,雖然在主函數(shù)中delete 父類,但最終只有父類的析構函數(shù),此時子類在堆區(qū)創(chuàng)建的s_name并沒有得到釋放,導致內(nèi)存泄漏。
以上的問題我們引入虛析構和純虛析構來解決——父類指針釋放子類對象時不干凈的問題
二、利用虛析構解決
虛析構只需要在析構函數(shù)前加關鍵字 virrtual 即可,再觀察結果,可以看到父類和子類的都執(zhí)行了析構函數(shù),而子類中在堆區(qū)創(chuàng)建的數(shù)據(jù)也被釋放干凈,這是最終的結果!
virtual ~Animal(){
cout<<"Animal析構"<<endl;
}
三、利用純虛析構解決
純虛析構格式如下,和純虛函數(shù)有點類似,但需要有具體的聲明和具體的實現(xiàn)。純虛析構需要在類外實現(xiàn).
class Animal{
public:
Animal(){
cout<<"Animal-構造"<<endl;
}
//虛析構
/*virtual ~Animal(){
cout<<"Animal析構"<<endl;
}*/
//純虛析構
virtual ~Animal()=0;
virtual void Run()=0; //純虛函數(shù)無需實現(xiàn),只需聲明
};
//需要有聲明,也需要有實現(xiàn)
Animal::~Animal(){
cout<<"純虛析構"<<endl;
}結果如下,和虛析構有相同的作用

四、總結
虛析構和純虛析構
相同點: 都可以解決父類指針釋放子類對象,都需要有具體的實現(xiàn)
不同點: 純虛析構屬于抽象類,無法實例化對象
到此這篇關于C++分析如何用虛析構與純虛析構處理內(nèi)存泄漏的文章就介紹到這了,更多相關C++內(nèi)存泄漏內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
一篇文章帶你了解C語言浮點數(shù)之間的比較規(guī)則
這篇文章主要介紹了魔性的float浮點數(shù)精度問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-08-08
C語言實例真題講解數(shù)據(jù)結構中單向環(huán)形鏈表
鏈表可以說是一種最為基礎的數(shù)據(jù)結構了,而單向鏈表更是基礎中的基礎。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護一組數(shù)據(jù)集合時,就可以使用鏈表,這一點和數(shù)組很相似2022-04-04

