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!

推薦閱讀: