当前在线人工客服
天达云-技术
QQ:1324027256
天达云-技术
QQ:1902643386
天达云-售前
QQ:1650874901
天达云-售前
QQ:2207995833
天达云-合作
QQ:1984186903
天达云微信小程序
400-837-6568

C++中为什么不要使用从破损的智能指针​获取的指针或引用
更新:HHH   时间:2023-1-7


本篇内容主要讲解“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++中为什么不要使用从破损的智能指针获取的指针或引用”有了更深的了解,不妨来实际操作一番吧!这里是天达云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

返回大数据教程...