析構(gòu)函數(shù)不可以聲明為虛函數(shù) 為什么基類的析構(gòu)函數(shù)定義為虛函數(shù)?
為什么基類的析構(gòu)函數(shù)定義為虛函數(shù)?我們經(jīng)常使用基類指針指向派生類對(duì)象,然后通過delete基類指針刪除派生類對(duì)象。此時(shí),為了確保派生類對(duì)象可以被完全析構(gòu)函數(shù),我們自然需要基類析構(gòu)函數(shù)是一個(gè)虛函數(shù)。這樣
為什么基類的析構(gòu)函數(shù)定義為虛函數(shù)?
我們經(jīng)常使用基類指針指向派生類對(duì)象,然后通過delete基類指針刪除派生類對(duì)象。此時(shí),為了確保派生類對(duì)象可以被完全析構(gòu)函數(shù),我們自然需要基類析構(gòu)函數(shù)是一個(gè)虛函數(shù)。這樣,在刪除的時(shí)候會(huì)調(diào)用派生類析構(gòu)函數(shù),否則只調(diào)用基類析構(gòu)函數(shù),派生類不能完全析構(gòu)函數(shù)出來(lái)的部分。
析構(gòu)函數(shù)為什么是虛函數(shù)?
使用delete PA指向基類引用時(shí),釋放PA引用的內(nèi)存,PA引用B object,為什么不調(diào)用B的析構(gòu)函數(shù)呢?這里,由于是靜態(tài)綁定,當(dāng)B在編譯時(shí)確定了它指向的函數(shù)時(shí),它不會(huì)根據(jù)對(duì)象a來(lái)確定它指向的函數(shù),這樣,如果B申請(qǐng)內(nèi)存資源,但不釋放析構(gòu)函數(shù)中的資源,就會(huì)導(dǎo)致內(nèi)存泄漏。
仔細(xì)想想,這不是虛擬功能的原因嗎?
添加了虛擬機(jī)制。編譯時(shí),虛擬機(jī)會(huì)自動(dòng)將方法指向B的地址,通過設(shè)置機(jī)制可以找到B的析構(gòu)函數(shù)。
為了改變這一點(diǎn),有一個(gè)虛擬析構(gòu)函數(shù)
只要基類的析構(gòu)函數(shù)設(shè)置為virtual type,所有派生類都會(huì)自動(dòng)將析構(gòu)函數(shù)設(shè)置為virtual type,以確保不會(huì)因?yàn)闆]有調(diào)用析構(gòu)函數(shù)而導(dǎo)致內(nèi)存泄漏。
C 中,為什么需要定義析構(gòu)函數(shù)為虛函數(shù)?
析構(gòu)函數(shù)不一定是虛擬函數(shù)。定義虛函數(shù)的目的是使用父類來(lái)管理子類。當(dāng)父類被解構(gòu)時(shí),它將調(diào)用子類的析構(gòu)函數(shù)(實(shí)際上,它是多態(tài)的),并直接使用父類來(lái)釋放子類。
析構(gòu)函數(shù)和虛函數(shù)的用法及作用?
析構(gòu)函數(shù)用于釋放已定義對(duì)象中使用的指針。不需要調(diào)用默認(rèn)的析構(gòu)函數(shù),而需要在程序結(jié)束時(shí)調(diào)用自建的析構(gòu)函數(shù)。虛函數(shù)可以使成員函數(shù)的運(yùn)算泛化。當(dāng)基類的指針指向不同派生類的對(duì)象時(shí),如果基類的指針調(diào)用其虛成員函數(shù),它將調(diào)用實(shí)際指向該對(duì)象的成員函數(shù),而不是基類中定義的成員函數(shù)(只要派生類更改成員函數(shù))。如果它不是虛函數(shù),則無(wú)論基類指針指向哪個(gè)派生類對(duì)象,都將調(diào)用在基類中定義的函數(shù)。