先看代码:
#include <iostream>
class A{
int m;
char* arr;
public:
A(int a);
~A();
};
#include <iostream>
#include "A.h"
A::A(int a){
if (a > 0){
printf("%s\n", __FUNCTION__);
arr = new char[a];
}
}
A::~A(){
printf("%s\n", __FUNCTION__);
if (NULL != arr){
printf("%s inside\n", __FUNCTION__);
delete []arr;
}
}
#include <iostream>
#include <memory>
class A;
class B{
std::auto_ptr<A> pA;
public:
B(int a);
};
#include "B.h"
#include "A.h"
B::B(int a):pA(new A(a)){
}
#include "B.h"
//#include "A.h"
int main(){
B* pB = new B(10);
delete pB;
//A a(10);
}
从输出看没有调用A的析构,那就内存泄露了,原因在于A在B.h前置声明,std::auto_ptr只能负责在生命期到了delete A;但是因为找不到A的具体信息,没有调用其析构,如果A的析构是trival的那还好,如果A里有其他资源那么就有内存泄露的危险。改正方法也很简单,在B.cpp写析构就行了。
那么就不能用std::auto_ptr了。