温馨提示×

温馨提示×

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

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

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

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

本篇内容主要讲解“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(实施建议)
  • (简单)如果函数调用时使用了一个从非局部智能指针变量(Unique_pointer or Shared_pointer)获取的指针或者引用,报警。智能指针是局部变量但是可能是别名时也报警。如果智能指针是一个Shared_pointer,建议获取一个智能指针的局部拷贝然后从该拷贝获取指针或引用。

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

向AI问一下细节

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

c++
AI