c++析構(gòu)函數(shù) 析構(gòu)函數(shù)為什么是虛函數(shù)?
析構(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ì)根
析構(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ù)對象a來確定它指向的函數(shù),這樣,如果B申請內(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ù)?在c 中純虛析構(gòu)函數(shù)的作用是什么?
有純虛擬功能,純虛擬破壞。我從沒聽說過純虛擬結(jié)構(gòu)。
虛函數(shù)是父類的成員函數(shù),后跟虛函數(shù)
純虛函數(shù)是虛函數(shù),后跟A=0;(如果不想在虛函數(shù)中寫入任何內(nèi)容,可以將其設(shè)為純虛)
虛析構(gòu)函數(shù),后跟虛析構(gòu)函數(shù),是純虛析構(gòu)函數(shù),后面是a=0。此外,還需要在類外部編寫一個(gè)空的析構(gòu)函數(shù)實(shí)現(xiàn)。
(我覺得純粹的虛擬解構(gòu)是無用的。人的純虛函數(shù)=0就是不用寫就實(shí)現(xiàn)了。解構(gòu)是不可避免的。既然你要解構(gòu),你就得省去寫作,然后在課堂上做一個(gè)空洞的解構(gòu)。為什么?