C++中为什么不要使用从破损的智能指针​获取的指针或引用

发布时间:2021-11-26 14:55:16 作者:iii
来源:亿速云 阅读:141

本篇内容主要讲解“C++中为什么不要使用从破损的智能指针获取的指针或引用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++中为什么不要使用从破损的智能指针获取的指针或引用”吧!

R.37: 不要使用从破损的智能指针获取的指针或引用

Reason(原因)

违反本规则是引用计数丢失和发生悬空指针的第一号理由。函数更应该沿着调用链向下传递原始指针和引用。你应该在调用树的最顶端,从可以保证对象存在的智能指针获得原始指针或引用。你需要保证智能指针不会在调用树的下面被不小心重置或者重新赋值。

Note(注意)

要做到这点,你需要获取一个智能指针的局部拷贝,通过它可以在函数和调用树执行期间将对象牢牢地锁定。

Example(示例)

考虑以下代码:

// global (static or heap), or aliased local ...
shared_ptr<widget> g_p = ...;

void f(widget& w)
{
   g();
   use(w);  // A
}

void g()
{
   g_p = ...; // oops, if this was the last shared_ptr to that widget, destroys the widget
}

下面的代码应该无法通过代码评审:

void my_code()
{
   // BAD: passing pointer or reference obtained from a non-local smart pointer
   //      that could be inadvertently reset somewhere inside f or its callees
   f(*g_p);

   // BAD: same reason, just passing it as a "this" pointer
   g_p->func();
}

为了改正这个问题--获取指针的局部拷贝以便为调用树“保持引用计数”。

void my_code()
{
   // cheap: 1 increment covers this entire function and all the call trees below us
   auto pin = g_p;

   // GOOD: passing pointer or reference obtained from a local unaliased smart pointer
   f(*pin);

   // GOOD: same reason
   pin->func();
}
Enforcement(实施建议)

到此,相信大家对“C++中为什么不要使用从破损的智能指针获取的指针或引用”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. c++智能指针的不断演化
  2. 关于c++ 智能指针及 循环引用的问题

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++

上一篇:TensorFlow如何安装及使用

下一篇:C#如何实现基于Socket套接字的网络通信封装

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》