您好,登錄后才能下訂單哦!
本篇內容主要講解“C++中為什么不要使用從破損的智能指針獲取的指針或引用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C++中為什么不要使用從破損的智能指針獲取的指針或引用”吧!
R.37: 不要使用從破損的智能指針獲取的指針或引用
違反本規則是引用計數丟失和發生懸空指針的第一號理由。函數更應該沿著調用鏈向下傳遞原始指針和引用。你應該在調用樹的最頂端,從可以保證對象存在的智能指針獲得原始指針或引用。你需要保證智能指針不會在調用樹的下面被不小心重置或者重新賦值。
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();
}
(簡單)如果函數調用時使用了一個從非局部智能指針變量(Unique_pointer or Shared_pointer)獲取的指針或者引用,報警。智能指針是局部變量但是可能是別名時也報警。如果智能指針是一個Shared_pointer,建議獲取一個智能指針的局部拷貝然后從該拷貝獲取指針或引用。
到此,相信大家對“C++中為什么不要使用從破損的智能指針獲取的指針或引用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。