本篇內(nèi)容介紹了“C++11智能指針shared_ptr怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)公司公司2013年成立,先為銀州等服務建站,銀州等地企業(yè),進行企業(yè)商務咨詢服務。為銀州企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。
shared_prt的本身是一個類,所以它的初始化實際上就是調(diào)用shared_ptr類的構(gòu)造函數(shù)。通過分析shared_ptr的構(gòu)造函數(shù),就可以準確把握shared_ptr初始化的方法。
default構(gòu)造函數(shù)
函數(shù)原型:
constexpr shared_ptr() noexcept;
說明:
聲明空shared_ptr。
代碼示例:
由空指針構(gòu)造
函數(shù)原型:
constexpr shared_ptr(nullptr_t);
說明:
通過空指針構(gòu)造shared_ptr,動作default構(gòu)造函數(shù)動作相同。
代碼實例:
由指針構(gòu)造
函數(shù)原型:
explicit shared_ptr (U* p);
說明:
根據(jù)已有指針構(gòu)造shared_ptr。
代碼實例:
注意事項
實例中展示的兩種方式都合法,但是在第二種情況中應該理解,一旦構(gòu)造了share_ptr,就表明s指向的string對象的內(nèi)存管理已經(jīng)交給ps1管理而不應該在通過s訪問了(至少是非常小心的訪問)。
第二種方式應該盡量避免。
拷貝構(gòu)造
函數(shù)原型:
shared_ptr (const shared_ptr& x) noexcept;
說明:
由一個已有的shared_ptr創(chuàng)建新的share_ptr。其間會自動維護應用計數(shù)。
代碼示例:
程序輸出:
拷貝構(gòu)造函數(shù)執(zhí)行以后,引用計數(shù)增加,兩個指針指向同一個對象。
移動構(gòu)造
函數(shù)原型:
shared_ptr (shared_ptr&& x) noexcept;
說明:
由一個已有的shared_ptr創(chuàng)建新的share_ptr。作為參數(shù)的shared_pt同時會釋放對內(nèi)存的管理權(quán)利,整個構(gòu)造過程結(jié)束后,引用計數(shù)不變。
代碼示例:
程序輸出:
內(nèi)存管理由ps轉(zhuǎn)移到了ps1。
修飾符說明
explicit:保證該構(gòu)造函數(shù)不會被隱式調(diào)用
noexcept:該函數(shù)不會拋出異常,
constexpr:該函數(shù)可以在編譯期間求值
“C++11智能指針shared_ptr怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!