本篇內(nèi)容主要講解“C++中為什么不要使用從破損的智能指針獲取的指針或引用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“C++中為什么不要使用從破損的智能指針獲取的指針或引用”吧!
專注于為中小企業(yè)提供做網(wǎng)站、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)南票免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了近千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
R.37: 不要使用從破損的智能指針獲取的指針或引用
違反本規(guī)則是引用計數(shù)丟失和發(fā)生懸空指針的第一號理由。函數(shù)更應(yīng)該沿著調(diào)用鏈向下傳遞原始指針和引用。你應(yīng)該在調(diào)用樹的最頂端,從可以保證對象存在的智能指針獲得原始指針或引用。你需要保證智能指針不會在調(diào)用樹的下面被不小心重置或者重新賦值。
Note(注意)
要做到這點,你需要獲取一個智能指針的局部拷貝,通過它可以在函數(shù)和調(diào)用樹執(zhí)行期間將對象牢牢地鎖定。
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
}
下面的代碼應(yīng)該無法通過代碼評審:
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();
}
為了改正這個問題--獲取指針的局部拷貝以便為調(diào)用樹“保持引用計數(shù)”。
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();
}
(簡單)如果函數(shù)調(diào)用時使用了一個從非局部智能指針變量(Unique_pointer or Shared_pointer)獲取的指針或者引用,報警。智能指針是局部變量但是可能是別名時也報警。如果智能指針是一個Shared_pointer,建議獲取一個智能指針的局部拷貝然后從該拷貝獲取指針或引用。
到此,相信大家對“C++中為什么不要使用從破損的智能指針獲取的指針或引用”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!