标签:释放 拷贝 void 动作 turn 通过 col 析构 防止
记住:
class Investment { ... }; Investment* createInvestment(); void f() { Investment* pInv = createInvestment(); ... // 若这里return了或者发生异常了,会导致delete调用不到 delete pInv; }
使用auto_ptr解决
void f() { std::auto_ptr<Investment> pInv(createInvestment()); ... //经由auto_ptr的析构函数自动删除pInv } //为了防止对象被删除一次以上,auto_ptr有个特性:若通过拷贝构造函数或者拷贝赋值操作复制它们,它们会变成null,而复制所得的指针将取得资源的唯一拥有权。 std::auto_ptr<Investment> pInv1(createInvestment()); std::auto_ptr<Investment> pInv2(pInv1); //现在pInv2指向对象,pInv1为null pInv1 = pInv2; //现在pInv1指向对象,pInv2为null
使用share_ptr解决
void f() { ... std::tr1::shared_ptr<Investment> pInv(createInvestment()); std::tr1::shared_ptr<Investment> pInv2(pInv1); //pInv1和pInv2指向同一个对象 pInv1 = pInv2; //同上 ... //经由shared_ptr的析构函数自动删除pInv1和pInv2指向的同一个对象 }
注意:
auto_ptr和tr1::shared_ptr两者都在其析构函数内做delete而不是delete[]操作。所以在动态分配而得到的array身上使用auto_ptr或tr1::shared_ptr是错误的。
比如:
std::auto_ptr<std::string> aps(new std::string[10]);
std::tr1::shared_ptr<int> spi(new int[1024]);
标签:释放 拷贝 void 动作 turn 通过 col 析构 防止
原文地址:https://www.cnblogs.com/pfsi/p/9194903.html