C++ std::make_unique和std::make_shared用法小結(jié)
std::make_unique 和 std::make_shared 是 C++11 引入的兩個輔助函數(shù),用于創(chuàng)建動態(tài)分配的智能指針 std::unique_ptr 和 std::shared_ptr,分別幫助避免了顯式使用 new 和 delete,從而提高代碼的安全性和可讀性。
std::make_unique:
#include <memory>
int main() {
// 使用 std::make_unique 創(chuàng)建動態(tài)分配的對象
std::unique_ptr<int> uniquePtr = std::make_unique<int>(42);
// 使用動態(tài)分配的對象
std::cout << *uniquePtr << std::endl;
// 不需要手動釋放內(nèi)存,unique_ptr 會在其生命周期結(jié)束時自動釋放
return 0;
}
std::make_unique 接受可變數(shù)量的參數(shù)并返回一個 std::unique_ptr,它在分配內(nèi)存和構(gòu)造對象時是一個原子操作。使用 std::make_unique 的優(yōu)點是可以避免內(nèi)存泄漏,因為它將分配和構(gòu)造操作合并在一起,如果構(gòu)造函數(shù)拋出異常,std::make_unique 會確保釋放已分配的內(nèi)存。
std::make_shared:
#include <memory>
int main() {
// 使用 std::make_shared 創(chuàng)建動態(tài)分配的對象
std::shared_ptr<int> sharedPtr = std::make_shared<int>(42);
// 使用動態(tài)分配的對象
std::cout << *sharedPtr << std::endl;
// 不需要手動釋放內(nèi)存,shared_ptr 會在最后一個引用消失時自動釋放
return 0;
}
std::make_shared 與 std::make_unique 類似,但它還有一個額外的優(yōu)勢,即在分配內(nèi)存時將引用計數(shù)分配在同一塊內(nèi)存中,從而減少了內(nèi)存開銷。std::make_shared 通常是推薦使用的方式,因為它可以提高性能,并在一些情況下減少內(nèi)存使用。
總的來說,使用 std::make_unique 和 std::make_shared 能夠簡化動態(tài)分配內(nèi)存和構(gòu)造對象的過程,提高代碼的安全性和可讀性。
到此這篇關(guān)于C++ std::make_unique和std::make_shared用法小結(jié)的文章就介紹到這了,更多相關(guān)C++ std::make_unique和std::make_shared內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++中std::ifstream::readsome和std::ifstream::read的區(qū)別解析
?std::ifstream::readsome和std::ifstream::read?的主要區(qū)別在于它們處理輸入流的方式和可能返回的結(jié)果,下面給大家介紹C++中std::ifstream::readsome和std::ifstream::read的區(qū)別解析,感興趣的朋友跟隨小編一起看看吧2024-08-08
新舊MFC版本實現(xiàn)CEdit透明的2種方法的實例代碼
新舊MFC版本實現(xiàn)CEdit透明的2種方法的實例代碼,需要的朋友可以參考一下2013-03-03
C++進階練習(xí)刪除鏈表的倒數(shù)第N個結(jié)點詳解
這篇文章主要給大家介紹了關(guān)于如何利用C++刪除鏈表的倒數(shù)第N個結(jié)點,文中通過實例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2022-05-05

