1. 所使用的类为预定义类

下面这段函数代码编译运行时没有问题的,不需要CPtr的定义

PtrUser.h

1
2
3
4
5
6
7
8
9
10
class  CPtr; // 预定义

class CPtrUser
{
public:
CPtrUser(CPtr* p):m_pPtr(p) { }
~CPtrUser() { delete m_pPtr; }
private:
CPtr* m_pPtr = nullptr;
};

当在Main中使用时,delete时,我们或许认为 m_pPtr 的析构函数会被调用

main.cpp

1
2
CPtrUser user = new CPtrUser(xxx);
delete user;

但实际上,如果PtrUser.h先被包含的话,delete m_pPtr时,是不会调用CPtr析构函数的。如果期望析构函数被调用,可以通过#include“Ptr.h” 把 CPtr的定义放入到PtrUser.h中,这样C++编译器就能识别该类型,编译时,为delete添加析构函数调用。

2. 转为父类,而父类没有声明virtual的虚析构函数

1
2
Parent* p = new Child();
delete p;

这种情况,Child的析构函数不会被调用。

1
2
3
4
5
6
7
class Parent { };

class Child : public Parent
{
public:
~Child() { }
};

要让被调用,可以简单修改为 :

1
2
3
4
5
class Parent
{
public:
virtual ~Parent() { };
};

转自:https://blog.csdn.net/danshiming/article/details/119782437