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

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

专注于为中小企业提供做网站、成都网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业南票免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

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

Reason(原因)

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

Note(注意)

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

Example(示例)

考虑以下代码:

// global (static or heap), or aliased local ...
shared_ptr 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++中为什么不要使用从破损的智能指针获取的指针或引用”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


网站栏目:C++中为什么不要使用从破损的智能指针​获取的指针或引用
文章转载:http://myzitong.com/article/jddjsd.html