9、对于new出来的内容都是放到heap中的,当不需要该内容的时,需要手动调用delete。如下的方式可以把new出来的资源放进资源管理
对象,利用资源管理对象的析构函数来确保资源的释放。
A* func();//返回指针,指向A动态分配的对象。
void f()
{
std::auto_ptr<A> p(func());
...
}
auto_ptr为智能指针,它的析构函数中会调用delete方法。
但是通过copy或copy assignment操作符复制它们,它们会变成NULL,而复制所得的指针将取得资源的唯一拥有权。
即:
std::auto_ptr<A> p1(func());
std::auto_ptr<A> p2(p1);//p2指向对象,而p1被设为NULL
p1 = p2; //p1指向对象,而p2被设为NULL
但是std::tr1::shared_ptr可以消除std::auto_ptr的这种情况,使p1和p2指向同一个对象。
注意:auto_ptr和shared_ptr的析构函数做的是delete而不是delete[],因此对象不能是数组对象。
10、隐式转换函数重载
class A
{
public:
...
operator B() const{};
}
A *a = new A();
B *b = (B*)a;
对象,利用资源管理对象的析构函数来确保资源的释放。
A* func();//返回指针,指向A动态分配的对象。
void f()
{
std::auto_ptr<A> p(func());
...
}
auto_ptr为智能指针,它的析构函数中会调用delete方法。
但是通过copy或copy assignment操作符复制它们,它们会变成NULL,而复制所得的指针将取得资源的唯一拥有权。
即:
std::auto_ptr<A> p1(func());
std::auto_ptr<A> p2(p1);//p2指向对象,而p1被设为NULL
p1 = p2; //p1指向对象,而p2被设为NULL
但是std::tr1::shared_ptr可以消除std::auto_ptr的这种情况,使p1和p2指向同一个对象。
注意:auto_ptr和shared_ptr的析构函数做的是delete而不是delete[],因此对象不能是数组对象。
10、隐式转换函数重载
class A
{
public:
...
operator B() const{};
}
A *a = new A();
B *b = (B*)a;
本文探讨了C++中使用new创建对象后的资源管理方法,重点介绍了std::auto_ptr和std::tr1::shared_ptr这两种智能指针的使用场景与区别。通过示例说明了如何避免内存泄漏,并讨论了隐式类型转换。
1116

被折叠的 条评论
为什么被折叠?



