当前位置: 首页 > news >正文

做puzzle的网站延庆上海网站建设

做puzzle的网站,延庆上海网站建设,优化关键词怎么做,wordpress响应式电商弱引用指针weak_ptr是用来监视shared_ptr的#xff0c;不会使引用计数器加1#xff0c;它不管理shared_ptr内部的指针#xff0c;主要是为了监视shared_ptr的生命周期#xff0c;更像是shared_ptr的一个助手。weak_ptr没有重载操作符*和-#xff0c;因为它不共享指针不会使引用计数器加1它不管理shared_ptr内部的指针主要是为了监视shared_ptr的生命周期更像是shared_ptr的一个助手。weak_ptr没有重载操作符*和-因为它不共享指针不能操作资源主要是为了通过shared_ptr获得资源的监测权它的构造函数不会增加引用计数它的析构不会减少引用计数纯粹只是作为一个旁观者来监视shared_ptr中管理的资源是否存在。weak_ptr还可以用来返回this指针和解决循环引用的问题。 weak_ptr基本用法 1、通过use_count()方法来获得当前观测资源的引用计数代码如下 #include memory #include iostream using namespace std;int main() {shared_ptrint sp(new int(1));weak_ptrint wp(sp);///输出1cout sp.use_count() endl;///输出1cout wp.use_count() endl;shared_ptrint sp2(new int(2));sp2 sp;///输出2cout sp.use_count() endl;return 0; } 2、通过expired()方法来判断所检测的资源是否已经被释放代码如下 #include memory #include iostream using namespace std;int main() {shared_ptrint sp(new int(1));weak_ptrint wp(sp);if (wp.expired()){cout weak_ptr无效所监视的智能指针被释放 endl;}else{cout weak_ptr 有效 endl;}return 0; } 3、通过lock方法来获取所监视的shared_ptr代码如下 #include memory #include iostream using namespace std;std::weak_ptrint gw;void f() {if (gw.expired()) ///所监听的shared_ptr是否被释放{cout gw is exipired endl;}else{auto spt gw.lock();cout *spt endl;} }int main() {{shared_ptrint sp(new int(1));gw sp;f();}f();return 0; } 输出如下 1 gw is expired weak_ptr返回this指针 不能直接将this指针返回为shared_ptr需要通过派生std::enable_shared_from_this类并通过其方法shared_from_this来返回智能指针原因是std::enable_shared_from_this类中有一个weak_ptr这个weak_ptr用来观测this指针调用shared_from_this()方法时会调用内部这个weak_ptr的lock()方法将所观测的shared_ptr返回看下面代码 #include memory #include iostream #include string #include string.h using namespace std;struct A : public std::enable_shared_from_thisA {shared_ptrA GetSelf(){return shared_from_this();}///析构函数调用了1次~A(){cout delete A endl;} };int main() {shared_ptrA sp1(new A);shared_ptrA sp2 sp1-GetSelf();return 0; } 输出结果如下 deleted A 在外面创建A对象的智能指针和通过该对象返回this的智能指针都是安全的因此shared_from_this是内部的weak_ptr调用lock()方法之后返回的智能指针在离开作用域之后sp1的引用计数减为0A对象会被析构不会出现A对象被析构两次的问题。 weak_ptr解决循环引用问题 智能指针的循环引用会导致内存泄漏问题请看下面的代码 #include memory #include iostream #include string #include string.h using namespace std;struct A; struct B;struct A {std::shared_ptrB bptr;~A(){cout A is deleted endl;} };struct B {std::shared_ptrA aptr;~B(){cout B is deleted endl;} };int main() {{///析构函数没有被调用shared_ptrA ap(new A);shared_ptrB bp(new B);ap-bptr bp;bp-aptr ap;///引用计数为2cout ap use_count: ap.use_count() endl;cout bp use_count: bp.use_count() endl;}return 0; } 在这个例子中由于循环引用导致ap和bp的引用计数都为2离开作用域之后引用计数减为1不会去删除指针导致内存泄漏。通过weak_ptr就可以解决这个问题只要将A或者B的任意一个成员变量改为weak_ptr即可。 struct A; struct B;struct A {std::shared_ptrB bptr;~A(){cout A is deleted endl;} };struct B {std::weak_ptrA aptr;~B(){cout B is deleted endl;} };int main() {{shared_ptrA ap(new A);shared_ptrB bp(new B);ap-bptr bp;bp-aptr ap;///引用计数为1cout ap use_count: ap.use_count() endl;cout bp use_count: bp.use_count() endl;}return 0; } 输出如下 ap use_count: 1 bp use_count: 2 A is deleted B is deleted 这样在对B的成员赋值时即执行bp-aptr ap;时由于aptr是weak_ptr它并不会增加引用计数所以ap的引用计数仍然会是1在离开作用域之后ap的引用计数会减少为0A指针会被析构析构后其内部的ptr的引用计数为减为1然后再离开作用域后bp引用计数又从1减到0B对象也会被析构不会发生内存泄漏。
http://www.pierceye.com/news/170876/

相关文章:

  • wordpress标签搜索引擎嘉兴市做网站优化
  • 网站更换关键词怎么做好wordpress post fonts
  • 厦门优化网站排名网站备案转服务器
  • 怎样做pdf电子书下载网站做旅行攻略的网站
  • 怎样做网站推广啊抖音网站的flash怎么做
  • 网站建设小说网站建设目标是什么意思
  • 如何做一个好的网站中英文网站好处
  • wordpress站点版权设置晋中建设集团网站
  • 怎么夸一个网站做的好看烟台百度网站推广
  • 佛山市网站建设分站多少钱企业门户账号是什么
  • 大中型网站开发价格铜山区建设局局网站周保春
  • 为什么有人做商城优惠券网站卖科技风格设计网站
  • 企业网站的需求分析是做网站编辑还是做平面设计
  • 超酷 flash 网站淮南网红餐厅
  • 湛江网站建设开发株洲关键词seo优化服务商
  • 女的有没有做网站的十大经典随身空间小说推荐
  • 江西做网站哪家好监理证查询网
  • 北京驾校网站建设网络哪里能接活做网站
  • 建设网站公司排名西宁网站建设优化案例
  • 外贸网站推广有用吗网络服务投诉平台
  • 网站制作价上传下载网站模板
  • 注册网站会员 我们的信息淘宝上可以做网站吗
  • 建筑材料价格查询网站做网站从哪方面入门
  • 百度百科网站怎么做360优化大师app下载
  • 那些网站用不着做优化个人网站设计案例
  • wordpress怎么釆集文章杭州seo百度关键词排名推广
  • 网站地址解析做好系部宣传和网站建设
  • 单页网站建设做淘宝优惠网站步骤
  • apache建立多个网站仿卢松松博客网站源码
  • 婚恋网站上海网络推广需要多少钱