谈谈C++中智能指针

auto_ptr

C++11已被抛弃。

unique_ptr

unique_ptr实现独占式拥有或严格拥有概念,确保同一时间内只有一个智能指针可以指向该对象。
但是,当程序试图将一个unique_ptr赋值给另一个时,如果源unique_ptr是个临时右值,编译器允许这么做;如果源unique_ptr将存在一段时间,编译器将禁止这么做。

unique_ptr<string> pu1(new string ("hello world"));
unique_ptr<string> pu2;
pu2 = pu1;//#1 不允许
unique_ptr<string> pu3;
pu3 = unique<string>(new string("you"));//#2允许

如果非要用#1这种情况,可以使用std::move()函数。告诉编译器自己知道后果。

unique_ptr<string> ps1,ps2;
ps1 = unique<string>(new string("hello"));
ps2 = move(ps1);
ps1 = unique<string>(new string("world"));

源unique_ptr必须重新赋值后才能使用。

shared_ptr

shared_ptr实现共享式拥有概念。多个智能指针可以指向相同对象。该对象和其相关资源会在“最后一个引用被销毁”时释放。
成员函数use_count()返回引用计数的个数;
成员函数unique()返回是否独占,即引用计数是不是1;
成员函数swap()交换两个shared_ptr对象,即交换所拥有的对象。
成员函数reset()放弃内部对象的所有权或拥有对象的变更,会引起原有对象的引用技术的减少。
成员函数get()返回内部对象(指针),由于已经重载()方法,所以和直接使用对象是一样的。

weak_ptr

shared_ptr存在内存泄漏的问题:当两个对象相互使用一个shared_ptr成员变量指向对方,会造成循环引用,使引用计数失效,从而导致内存泄漏。
weak_ptr是一种不控制对象生命周期的智能指针,它指向一个shared_ptr管理的对象。进行该对象的内存管理的是那个强引用的shared_ptr,weak_ptr只是提供了对管理对象的一个访问手段。weak_ptr的引入是为了配合shared_ptr使用。
weak_ptr只可以从一个shared_ptr或者另一个weak_ptr对象构造,它的构造和析构不会引起引用计数的减少或增加。
不能通过weak_ptr直接访问对象的方法,应该先把它转化为shared_ptr。
成员函数expored()用于检测所管理的对象是否已经释放。如已经释放,返回Ture;
成员函数lock()用于获取所管理的对象的强引用(shared_ptr)。如果expired为True,返回一个空的shared_ptr;
成员函数use_count()返回与shared_ptr共享的对象的引用计数;
成员函数reset()将weak_ptr置空;
weak_ptr支持拷贝和赋值。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值