c++智能指針unique_ptr的使用
1.為什麼需要unique_ptr
與shared_ptr作用類似,需要解決內存泄漏的問題,但是卻不需要使用shared_ptr的引用計數,所以為瞭減少消耗,就需要一個這樣的智能指針。但是使用已被廢棄的auto_ptr的話就會有新的問題,auto_ptr在使用過程中如果被拷貝構造或者賦值的話,被復制的auto_ptr就失去瞭作用,這個時候就需要在auto_ptr的基礎上禁用拷貝構造以及賦值操作,也就成瞭unique_ptr。
2.什麼是unique_ptr
一個unique_ptr獨享它指向的對象。也就是說,同時隻有一個unique_ptr指向同一個對象,當這個unique_ptr被銷毀時,指向的對象也隨即被銷毀。使用unique_ptr需要引入<memory.h>
3.unique_ptr特性
unique_ptr禁用瞭拷貝構造以及賦值操作,也就導致瞭下面的這些操作無法完成。
void testFunction(std::unique_ptr<Test> t){ t->getString(); } void features(){ // Disable copy from lvalue. // unique_ptr(const unique_ptr&) = delete; // unique_ptr& operator=(const unique_ptr&) = delete; //不能進行拷貝構造以及賦值運算,也就表示不能作為函數參數傳遞 std::unique_ptr<Test> t(new Test); std::unique_ptr<Test> t2 = t; //編譯報錯 std::unique_ptr<Test> t3(t);//編譯報錯 testFunction(t);//編譯報錯 }
4.如何使用unique_ptr
4.1簡單使用
void simpleUse(){ Test *test = new Test; std::unique_ptr<Test> t(test); qDebug() << test <<"獲取原始指針"<< t.get() <<endl; // t.release(); //釋放其關聯的原始指針的所有權,並返回原始指針,沒有釋放對象 // t.reset();// 釋放對象 t->getString(); std::unique_ptr<Test> t2 = std::move(t); //交換使用權到t2; t2->getString(); }
4.2指向數組
和shared_ptr需要註意的地方一樣,指向數組時要註意模板書寫的方式,以及如何使用自定義刪除器
錯誤寫法:會導致內存泄露
void customRemover(){ std::unique_ptr<Test> t(new Test[5]); }
正確寫法:
void customRemover(){ std::unique_ptr<Test[]> t(new Test[5]); std::unique_ptr<Test, void(*)(Test *)> p2(new Test[5],[](Test *t){ delete []t; }); }
5.unique_ptr需要註意什麼
不要多個unique_ptr指向同一個對象
例如:
void repeatPointsTo(){ Test *test = new Test; std::unique_ptr<Test> t(test); std::unique_ptr<Test> t2(test); //兩個unique_ptrzhi'xi指向同一個對象,會導致這個對象被析構兩次,導致問題出現 }
會導致對象會被多次析構,導致崩潰
到此這篇關於c++智能指針unique_ptr的使用的文章就介紹到這瞭,更多相關c++智能指針unique_ptr內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!