boost shared ptr内部结构

本文介绍了C++中的智能指针boost::shared_ptr,包括其设计理念、使用方式以及内部结构。通过示例展示了如何在vector中使用shared_ptr,并解释了引用计数的概念。文章还探讨了shared_ptr如何处理多对象共享引用计数的问题,以及其内部的shared_count类和sp_counted_base类的角色。最后,提到了智能指针在避免内存泄漏和管理对象生命周期中的作用。
摘要由CSDN通过智能技术生成
               

本文是从过去自己的一篇博客中修改而来。因为年代久了,这篇博客的图片被CSDN升级搞丢了。所以现在重新绘制了结构图。

老文位置:http://blog.csdn.net/sheismylife/article/details/1694939

shared_ptr
    shared_ptr源自于著名的boost库,智能指针自从Scott Meyers在其作品<<More Effective C++>>首次提出并给出一个示范版本后得到了很大的发展。Loki和Boost是影响广泛的两个,Boost的智能指针较易使用,而Loki以功能强大思想深邃著称于世。C++标准委员会的人虽然对Loki赞赏有加,但是易用性似乎占了上风,于是Boost中的shared_ptr和weak_ptr出现在了C++标准的修改版中。现在可以肯定的是,C++09标准中一定会出现的是shared_ptr和weak_ptr两个指针。
    下面的关于shared_ptr的介绍,摘自马维达几年前的一篇文章《智能指针的标准之争:Boost vs. Loki》:
    shared_ptr:意在用于对被指向对象的所有权进行共享。被指向对象也保证会被删
除,但是这将发生在最后一个指向它的shared_ptr 被销毁时,或是调用reset 方法时。    shared_ptr符合C++标准库的“可复制构造”(CopyConstructible)和“可赋值”(Assignable)要求,所以可被用于标准的库容器中。另外它还提供了比较操作符,所以可与标准库的关联容器一起工作。shared_ptr 不能用于存储指向动态分配的数组的指针,这样的情况应该使用shared_array。该模板的实现采用了引用计数技术,所以无法正确处理循环引用的情况。可以使用weak_ptr 来“打破循环”。shared_ptr 还可在多线程环境中使用。
    下面的例子演示了如何在vector中使用shared_ptr:
class CTest
{
    ...
};
typedef boost::shared_ptr<CTest> TestPtr;
void PT(const TestPtr &t)
{
    std::cout << "id: " << t->GetId() << "/t/t";
    std::cout<< "use count: " << t.use_count() << '/n';
}
void main()
{
    std::vector<TestPtr> TestVector;
    TestPtr pTest0(new CTest(0));
    TestVector.push_back(pT

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值