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()
{
};
};