scoped_ptr

scoped_ptr是一个很类似auto_ptr的智能指针,它包装了new操作符在堆上分配的动态对象,能够保证动态创建的对象在任何时候都可以被正确的删除,但很重要的一点是scoped_ptr获取了对象的管理权,就无法再从它那里取回来

它只在对象析构的时候释放一次,对象析构的时候自动释放内存

source code

template<class T>
class scoped_ptr{
private:
T *px;
//private意味着指针不能被转让所有权
scoped_ptr(scoped_ptr const &);
scoped_ptr & operator=(scoped_ptr const &);
public:
explicit scoped_ptr(T * p =0);
~scoped_ptr();
//删除原指针,再保存新指针,如果p是空指针,scoped_ptr将不持有任何指针
void reset(T* p=0);
T & operator*()const;
T * operator->()const;
//返回scoped_ptr内部保存的原始指针,但不能对原始指针进行delete操作
T * get()const;

operator unspecified-bool-type() const;
void swap(scoped_ptr & b);
};



用法:不允许拷贝和赋值

#include<boost/smart_ptr.hpp>
#include<iostream>
using namespace boost;
using namespace std;

class A
{
public:
A(){
cout << "A()" << endl;
}
~A(){
cout << "~A()" << endl;
}
};

int main()
{
scoped_ptr<int> p1(new int);
*p1 = 100;
cout << *p1 << endl;
scoped_ptr<int> p2(new int);
*p2 = 200;
cout << *p2 << endl;
//p1 = p2;不能转让所有权
p1.reset();//now p is null
if(p1)
cout << *p1 << endl;//this code will not be execute
scoped_ptr<A> p3(new A);
}


100
200
A()
~A()


auto_ptr是可以转让的

#include<boost/smart_ptr.hpp>
#include<iostream>
#include<cassert>
using namespace boost;
using namespace std;

int main()
{
auto_ptr<int> ap(new int(10));
cout << *ap << endl;
scoped_ptr<int> sp(ap);//now ap is null
assert(ap.get()==0);
ap.reset(new int(101));
cout << *ap << "," << *ap.get() << endl;
}

10
101,101
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值