C++的虛析構(gòu)詳解及實(shí)例代碼
C++的虛析構(gòu)
最近準(zhǔn)備復(fù)習(xí)一遍所有的知識(shí)點(diǎn),先從基礎(chǔ)開始做起,用幾分鐘寫個(gè)繼承和析構(gòu)吧。
父類為A,子類為B,代碼如下:
class A
{
public:
A()
{
cout << "構(gòu)造A"<< endl;
}
~A()
{
cout << "析構(gòu)A" << endl;
}
}
class B:public A
{
public:
B()
{
cout << "構(gòu)造B"<< endl;
}
~B()
{
cout << "析構(gòu)B"<< endl;
}
}
這個(gè)時(shí)候在main函數(shù)里,
定義一個(gè)A的對(duì)象,A a;運(yùn)行輸出結(jié)果為:構(gòu)造A 析構(gòu)A。
定義一個(gè)B的對(duì)象, B b;運(yùn)行的輸出結(jié)果為:構(gòu)造B 析構(gòu)B。
定義一個(gè)A的指針,指向B。A *P = new b; 運(yùn)行輸出結(jié)果為:構(gòu)造A 構(gòu)造B.這個(gè)時(shí)候很多人就容易出問題了,為啥沒調(diào)用析構(gòu)呢,這個(gè)也是經(jīng)常遇到的問題,最簡(jiǎn)單也是最容易遺忘的。new出來的對(duì)象沒有刪,還有寫一行代碼 delete p;這個(gè)時(shí)候的運(yùn)行輸出結(jié)果為:構(gòu)造A 構(gòu)造B 析構(gòu)A。又出現(xiàn)問題了,B的析構(gòu)怎么沒走,這個(gè)時(shí)候需要一用虛析構(gòu)這個(gè)概念,虛析構(gòu)的功能:父類的析構(gòu)寫成虛析構(gòu),在刪除父類的指針的時(shí)候,可以刪除子類的對(duì)象,避免內(nèi)存泄漏。
具體操作就是把上面代碼的第八行,前面加一個(gè)virtual。這個(gè)時(shí)候再運(yùn)行輸出結(jié)果為:構(gòu)造A 構(gòu)造B 析構(gòu)B 析構(gòu)A。注意這里也可以看出調(diào)用順序,先走父類的構(gòu)造,然后子類的構(gòu)造。先走子類的析構(gòu),最后走父類的析構(gòu)。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
C語言實(shí)現(xiàn)ATM機(jī)存取款系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)ATM機(jī)存取款系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
C語言實(shí)現(xiàn)圖書管理系統(tǒng)課程設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)圖書管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
VsCode搭建C語言運(yùn)行環(huán)境詳細(xì)過程及終端亂碼問題解決方案
這篇文章主要介紹了VsCode搭建C語言運(yùn)行環(huán)境以及終端亂碼問題解決,在VsCode中搭建C/C++運(yùn)行環(huán)境需要先安裝幾個(gè)插件,具體插件文中給大家詳細(xì)介紹,需要的朋友可以參考下2022-12-12
簡(jiǎn)單掌握Linux系統(tǒng)中fork()函數(shù)創(chuàng)建子進(jìn)程的用法
fork()函數(shù)只能在類Unix系統(tǒng)下使用,因?yàn)樾枰雞nistd頭文件,這里我們就來簡(jiǎn)單掌握Linux系統(tǒng)中fork()函數(shù)創(chuàng)建子進(jìn)程的用法,需要的朋友可以參考下2016-06-06
簡(jiǎn)單聊聊C++中線程的原理與實(shí)現(xiàn)
C++11?引入了多線程支持,提供了一套基本的線程庫,包括線程、互斥量(mutex)、條件變量(condition_variable)等。這些組件可以幫助你在?C++?程序中實(shí)現(xiàn)并發(fā)和多線程編程,本文就來和大家簡(jiǎn)單聊聊吧2023-03-03
詳解如何利用C++實(shí)現(xiàn)Mystring類
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)MyString的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
C++歸并法+快速排序?qū)崿F(xiàn)鏈表排序的方法
這篇文章主要介紹了C++歸并法+快速排序?qū)崿F(xiàn)鏈表排序的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04

