前置声明的危急
先看代码:
#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里有其它资源那么就有内存泄露的危急。
改正方法也非常easy。在B.cpp写析构即可了。
那么就不能用std::auto_ptr了。
浙公网安备 33010602011771号