delete不调用析构函数的两种情况
生活随笔
收集整理的這篇文章主要介紹了
delete不调用析构函数的两种情况
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 所使用的類為預定義類
下面這段函數代碼編譯運行時沒有問題的,不需要CPtr的定義
---PtrUser.h
class CPtr; // 預定義 class CPtrUser { public:CPreUser():m_pPtr(null);{}~CPreUser(){delete m_pPtr;}void SetPtr(CPtr* p){m_pPtr = p;} private:CPtr* m_pPtr; };當在Main中使用時,delete時,我們或許認為 m_pPtr 的析構函數會被調用
---main.cpp
CPtrUser user = new CPtrUser(); user->SetPtr(xxx); // 其中xxx為CPtr類型指針 delete user;但實際上,如果PtrUser.h先被包含的話,delete m_pPtr時,是不會調用CPtr析構函數的。如果期望析構函數被調用,可以通過#include“Ptr.h” 把 CPtr的定義放入到PtrUser.h中,這樣C++編譯器就能識別該類型,編譯時,為delete添加析構函數調用。
2. 轉為父類,而父類沒有聲明virtual的虛析構函數
Parent* p = new Child(); delete p;?這種情況,Child的析構函數不會被調用。
class Parent { };class Child : public Parent { public:Child(){}~Child(){} };?要讓被調用,可以簡單修改為 :
class Parent { public:virtual ~Parent(){}; };本文轉自:內存泄漏-Delete不調用析構函數的兩種情況_春夜喜雨的專欄-CSDN博客
總結
以上是生活随笔為你收集整理的delete不调用析构函数的两种情况的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 苹果8p尺寸长度和宽度(苹果官网报价)
- 下一篇: std::ostream_iterato