Technical Report 1 是一份规范,描述加入C++标准程序的诸多新技能,以新的class templates 和 function templates 形式体现,针对的题目有哈希表,基于引用计数的智能指针,正则表达式等。大多数TR1机能是以Boost的工作为基础的。TR组件位于std::tr1命名空间中。

tr1::shared_ptr 的使用和boost::shared_ptr 类似,都是基于引用计数值的智能指针。#include <memory> 以使用shared_ptr。

1. 在可能会引起循环引用的地方,使用weak_ptr。

[cpp] view plaincopyprint?
  1. #include <iostream>
  2. #include <memory>
  3. class A;
  4. class B;
  5. typedef std::tr1::shared_ptr<A> APtr;
  6. typedef std::tr1::shared_ptr<B> BPtr;
  7. class A
  8. {
  9. public:
  10. BPtr b;
  11. ~A()
  12. {
  13. std::cout << "A released." << std::endl;
  14. }
  15. };
  16. class B
  17. {
  18. public:
  19. APtr a;
  20. ~B()
  21. {
  22. std::cout << "B released." << std::endl;
  23. }
  24. };
  25. int _tmain(int argc, _TCHAR* argv[])
  26. {
  27. APtr objA(new A());
  28. BPtr objB(new B());
  29. objA->b = objB; //1
  30. objB->a = objA; //2
  31. return 0;
  32. }
<span style="font-size:12px;">#include <iostream>
#include <memory>class A;
class B;
typedef std::tr1::shared_ptr<A> APtr;
typedef std::tr1::shared_ptr<B> BPtr;class A
{
public:BPtr b;~A(){std::cout << "A released." << std::endl;}
};class B
{
public:APtr a;~B(){std::cout << "B released." << std::endl;}
};int _tmain(int argc, _TCHAR* argv[])
{APtr objA(new A());BPtr objB(new B());objA->b = objB; //1objB->a = objA; //2return 0;
}</span>

执行完什么也没有输出,说明 A  和 B 都没有执行析构函数,资源泄漏了。指针objA 的生命周期结束时,对其的引用计数为1,即objB手中的引用,所以对象objA不会释放。objB 同理。注释为 1 和 2 的两句,任意去掉一句,就打破了循环引用,objA 和 objB 都能正常释放。

如果两个对象之间需要互相引用,使用std::tr1::weak_ptr,它不会增加引用计数,当需要使用这个对象的时候,可以从weak_ptr中临时生出一个shared_ptr 来(引用计数+1),这个临时的shared_ptr 生命结束后,会把引用计数减小 1,避免出现互相死锁的情况。

[cpp] view plaincopyprint?
  1. #include <iostream>
  2. #include <memory>
  3. class A;
  4. class B;
  5. typedef std::tr1::shared_ptr<A> APtr;
  6. typedef std::tr1::shared_ptr<B> BPtr;
  7. typedef std::tr1::weak_ptr<A> AWeakPtr;
  8. typedef std::tr1::weak_ptr<B> BWeakPtr;
  9. class A
  10. {
  11. public:
  12. BWeakPtr b;
  13. ~A()
  14. {
  15. std::cout << "A released." << std::endl;
  16. }
  17. };
  18. class B
  19. {
  20. public:
  21. AWeakPtr a;
  22. ~B()
  23. {
  24. std::cout << "B released." << std::endl;
  25. }
  26. void Print()
  27. {
  28. std::cout << "I'm in B!" << std::endl;
  29. }
  30. };
  31. class C : public std::tr1::enable_shared_from_this<C>
  32. {
  33. public:
  34. std::tr1::shared_ptr<C> getSharedPtr()
  35. {
  36. return shared_from_this();
  37. }
  38. };
  39. int _tmain(int argc, _TCHAR* argv[])
  40. {
  41. APtr objA(new A());
  42. BPtr objB(new B());
  43. objA->b = objB;
  44. objB->a = objA;
  45. BPtr objB2(objA->b.lock()); //获得shared_ptr
  46. objB2->Print();
  47. return 0;
  48. }
<span style="font-size:12px;">#include <iostream>
#include <memory>class A;
class B;
typedef std::tr1::shared_ptr<A> APtr;
typedef std::tr1::shared_ptr<B> BPtr;
typedef std::tr1::weak_ptr<A> AWeakPtr;
typedef std::tr1::weak_ptr<B> BWeakPtr;class A
{
public:BWeakPtr b;~A(){std::cout << "A released." << std::endl;}
};class B
{
public:AWeakPtr a;~B(){std::cout << "B released." << std::endl;}void Print(){std::cout << "I'm in B!" << std::endl;}
};class C : public std::tr1::enable_shared_from_this<C>
{
public:std::tr1::shared_ptr<C> getSharedPtr(){return shared_from_this();}
};int _tmain(int argc, _TCHAR* argv[])
{APtr objA(new A());BPtr objB(new B());objA->b = objB;objB->a = objA;BPtr objB2(objA->b.lock()); //获得shared_ptrobjB2->Print();return 0;
}</span>

在 A 和 B 内部都使用weak_ptr,weak_ptr 的 lock(),相当于 shared_ptr 的 get()。对上例来说,其实只需要一个地方使用weak_ptr就可以了。

2. 从对象的原始指针,生成需要的shared_ptr。

使用std::tr1::enable_shared_from_this 作为基类。这样可以从 this 生成具有统一计数的 shared_ptr了。

[cpp] view plaincopyprint?
  1. class C : public std::tr1::enable_shared_from_this<C>
  2. {
  3. public:
  4. std::tr1::shared_ptr<C> getSharedPtr()
  5. {
  6. return shared_from_this();
  7. }
  8. };
<span style="font-size:12px;">class C : public std::tr1::enable_shared_from_this<C>
{
public:std::tr1::shared_ptr<C> getSharedPtr(){return shared_from_this();}
};</span>

shared_from_this() 不能在构造函数中使用,因为在 enable_shared_from_this 这个基类内部,是通过一个对自己的 weak_ptr 的引用来返回 this 的shared_ptr 的,而在对象的构造函数中,第一个 shared_ptr 尚未获得指针,所以 weak_ptr 是空的,shared_from_this() 返回会失败。

sp_counted_base_w32.hpp

[cpp] view plaincopyprint?
  1. void add_ref_copy()
  2. {
  3. BOOST_INTERLOCKED_INCREMENT( &use_count_ );
  4. }
<span style="font-size:12px;">    void add_ref_copy(){BOOST_INTERLOCKED_INCREMENT( &use_count_ );}
</span>
[cpp] view plaincopyprint?
  1. void release() // nothrow
  2. {
  3. if( BOOST_INTERLOCKED_DECREMENT( &use_count_ ) == 0 )
  4. {
  5. dispose();
  6. weak_release();
  7. }
  8. }

C++学习 std::tr1::shared_ptr使用的一点体会tr1库介绍相关推荐

  1. 未来最佳企业形态和商业模式的雏形——学习《维基经济学》的一点体会

    未来最佳企业形态和商业模式的雏形                                                                                     ...

  2. 前端学习(2865):公开课封装组件库介绍

  3. C++ std::tr1::shared_ptr使用说明

    1. 介绍 shared_ptr 是通过指针保持某个对象的共享拥有权的智能指针. 若干个 shared_ptr 对象能够拥有同一个对象:最后一个指向该对象的 shared_ptr 被销毁或重置时.该对 ...

  4. 【转】C++ std::tr1::shared_ptr使用

    看<effective c++>,作者一直强调用std::tr1::shared_ptr,比起auto_ptr好多了. shared_ptr采用引用计数,多个指针可以指向同一个对象:aut ...

  5. C++学习 一、shared_ptr使用

    C++学习 一.shared_ptr使用 前言 shared_ptr概述 创建shared_ptr对象 0 声明shared_ptr对象 1 通过堆指针创建shared_ptr对象 2 通过拷贝构造函 ...

  6. C#线程学习的一点体会和总结

    C#线程学习如同在Java中一样,在c#中写一个多线程应用是非常简单的,本章将介绍如何在c#种开发多线程程序.在.net中线程是由System.Threading 名字空间所定义的.所以你必须包含这个 ...

  7. 每天学习一个知识点,每天进步一点

    每天学习一个知识点,每天进步一点. 我觉得,编程就是如此,我也如此. 如果不是学习,不去操作,就会忘记的. 呵呵,大家觉得如何?

  8. 有关英语学习的一点体会(转载)

    有关英语学习的一点体会(原创)-----欢迎大家拍砖 Beth(bethz@263.net) (转载请注明作者,否则保留追究的权力) 记得我一个老师说过"English is a frien ...

  9. OpenCV学习笔记(三十一)——让demo在他人电脑跑起来 OpenCV学习笔记(三十二)——制作静态库的demo,没有dll也能hold住 OpenCV学习笔记(三十三)——用haar特征训练自己

    OpenCV学习笔记(三十一)--让demo在他人电脑跑起来 这一节的内容感觉比较土鳖.这从来就是一个老生常谈的问题.学MFC的时候就知道这个事情了,那时候记得老师强调多次,如果写的demo想在人家那 ...

最新文章

  1. KDE与GNOME的战争史(转载)
  2. 基础知识——用户输入和函数(五)
  3. 控件属性、事件持久化
  4. VTK修炼之道53:图形基本操作进阶_多分辨率策略(模型细化的三种方法)
  5. 李彦宏被泼水背后,这些python AI发展的大事你都了解吗?
  6. P4899 [IOI2018] werewolf 狼人(kruskal 重构树 + 主席树)
  7. vue-beauty UI库
  8. 小爱同学App下架苹果App Store 网友:SiriOS警告?
  9. 面试了上百位性能测试后,我发现了一个令人不安的事实
  10. .net core精彩实例分享 -- 面向对象编程
  11. excel删除行 uipath_高级会计师都在用的Excel批处理技巧,祝你早日告别加班
  12. Navicat for MySQL 连接 Mysql 8.0.16 时报错1251- Client does not support.....的解决办法
  13. 06-20210308华为海思Hi3516DV300鸿蒙系统的uboot编译
  14. 电脑桌面的照片文件不见了怎么办
  15. asp实训报告摘要_ASP实训总结
  16. 故事版xib --view上添加tableview
  17. win10高性能模式
  18. 干货!小样本分子性质预测新方法——性质感知的关系网络
  19. 串口TXD和RXD的线序导致不能通信的问题
  20. Android AVD Manager - 安卓虚拟机的设置

热门文章

  1. Matlab验证码识别
  2. 3-33在图 3-31中,以太网交换机有6个接口,分别接到5台主机和一个路由器。在下面表中的“动作”一栏中,表示先后发送了4个帧。假定在开始时,以太网交换 机的交换表是空的。试把该表中其他的栏目都填写
  3. 王道计算机组成原理课代表 - 考研计算机 第七章 输入输出系统 究极精华总结笔记
  4. 消费金融及物流概念介绍
  5. 用于地址解析的协议是服务器,用于解析域名的协议是什么?
  6. 该战斗的时候战斗,该转身的时候转身,但请保持优雅
  7. bat脚本使用winRAR命令行压缩文件
  8. 通俗易懂的Kafka零拷贝机制
  9. 疯癫中的娱乐_ITfengbao
  10. vue 监听输入法方法(js)