scope_ptr

scope_ptr是一个很类似auto_ptr的智能指针,它包装了new操作符在堆上分配的动态对象,能够保证动态创建的对象在任何时候都可以被正确地删除。

但scope_ptr的所有权更加严格,不能转让,一旦scope_ptr获得了对象的管理权,你就无法再从它那里取回来.


scope_ptr不允许拷贝,赋值,只能在scope_ptr被声明的作用域内使用,除了*和->外scope_ptr也没有定义其他的操作符(不能对scope_ptr进行++或者--等

指针算术操作),与普通指针相比它只有很小的接口,因此使指针的使用更加安全,更容易使用同时更不容易被误用。

sp++;                                               //错误,scope_ptr未定义递增操作符

scope_ptr<string>  sp2=sp;           //错误,scope_ptr不能拷贝构造




scope_ptr的用法与auto_ptr几乎一样,大多数情况下它可以与auto_ptr相互替换,也可以从一个auto_ptr获得指针的管理权(同时auto_ptr失去管理权)

scope_ptr和auto_ptr同样的“缺陷”,不能用作容器的元素,但原因不同:

auto_ptr是因为它的转移语义,而scope_ptr则是因为不支持拷贝和赋值,不符合容器对元素类型的要求。


scope_ptr与auto_ptr的根本区别在于指针的所有权。auto_ptr特意被设计为指针的所有权是可转移的,可以在函数之间传递,

同一个时刻只能有一个auto_ptr管理指针,他的用意是好的,scope_ptr把拷贝构造函数和赋值函数都声明为私有的,拒绝了指针的所有权转让,

任何人都无权访问被管理的指针,从而保证了指针的绝对安全。

auto_ptr<int>  ap(new int(10));

scope_ptr<int> sp(ap);

assert(ap.get()==0);


ap.reset(new int(20));

cout<<*ap<<","<<*sp<endl;


auto_ptr<int> ap2;

ap2=ap;

assert(ap.get()==0)

scope_ptr<int> sp2;

sp2=sp;      //赋值错误,无法通过编译

如果代码编写者企图从一个scope_ptr构造或赋值另一个scope_ptr,那么编译器会报出一个错误,阻止他这么做,从而保护了你的代码,而且是在编译器.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值