您好,登錄后才能下訂單哦!
本篇內容介紹了“C++11智能指針shared_ptr怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
shared_prt的本身是一個類,所以它的初始化實際上就是調用shared_ptr類的構造函數。通過分析shared_ptr的構造函數,就可以準確把握shared_ptr初始化的方法。
default構造函數
函數原型:
constexpr shared_ptr() noexcept;
說明:
聲明空shared_ptr。
代碼示例:
由空指針構造
函數原型:
constexpr shared_ptr(nullptr_t);
說明:
通過空指針構造shared_ptr,動作default構造函數動作相同。
代碼實例:
由指針構造
函數原型:
explicit shared_ptr (U* p);
說明:
根據已有指針構造shared_ptr。
代碼實例:
注意事項
實例中展示的兩種方式都合法,但是在第二種情況中應該理解,一旦構造了share_ptr,就表明s指向的string對象的內存管理已經交給ps1管理而不應該在通過s訪問了(至少是非常小心的訪問)。
第二種方式應該盡量避免。
拷貝構造
函數原型:
shared_ptr (const shared_ptr& x) noexcept;
說明:
由一個已有的shared_ptr創建新的share_ptr。其間會自動維護應用計數。
代碼示例:
程序輸出:
拷貝構造函數執行以后,引用計數增加,兩個指針指向同一個對象。
移動構造
函數原型:
shared_ptr (shared_ptr&& x) noexcept;
說明:
由一個已有的shared_ptr創建新的share_ptr。作為參數的shared_pt同時會釋放對內存的管理權利,整個構造過程結束后,引用計數不變。
代碼示例:
程序輸出:
內存管理由ps轉移到了ps1。
修飾符說明
explicit:保證該構造函數不會被隱式調用
noexcept:該函數不會拋出異常,
constexpr:該函數可以在編譯期間求值
“C++11智能指針shared_ptr怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。