您好,登錄后才能下訂單哦!
這篇文章主要講解了C++11中的unique_ptr的詳細用法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
在前面一篇文章中,我們了解了C++11中引入的智能指針之一shared_ptr 和 weak_ptr ,今天,我們來介紹一下另一種智能指針 unique_ptr 。
往期文章參考:
【C++11新特性】 C++11 智能指針之shared_ptr
【C++11新特性】 C++11智能指針之weak_ptr
unique_ptr介紹
unique是獨特的、唯一的意思,故名思議,unique_ptr可以“獨占”地擁有它所指向的對象,它提供一種嚴格意義上的所有權。
這一點和我們前面介紹的 shared_ptr 類型指針有很大的不同:shared_ptr 允許多個指針指向同一對象,而 unique_ptr 在某一時刻只能有一個指針指向該對象。
unique_ptr 保存指向某個對象的指針,當它本身被刪除或者離開其作用域時會自動釋放其指向對象所占用的資源。
1、如何創建unique_ptr
unique_ptr 不像shared_ptr一樣擁有標準庫函數make_shared來創建一個shared_ptr實例。
要想創建一個 unique_ptr,我們需要將一個 new 操作符返回的指針傳遞給unique_ptr的構造函數。
示例:
int main() { // 創建一個unique_ptr實例 unique_ptr<int> pInt(new int(5)); cout << *pInt; }
2、無法進行復制構造和賦值操作
unique_ptr沒有 copy 構造函數,不支持普通的拷貝和賦值操作。
示例:
int main() { // 創建一個unique_ptr實例 unique_ptr<int> pInt(new int(5)); unique_ptr<int> pInt2(pInt); // 報錯 unique_ptr<int> pInt3 = pInt; // 報錯 }
3、可以進行移動構造和移動賦值操作
unique_ptr雖然沒有支持普通的拷貝和賦值操作,但卻提供了一種移動機制來將指針的所有權從一個unique_ptr轉移給另一個unique_ptr。
如果需要轉移所有權,可以使用std::move()函數。
示例:
int main() { unique_ptr<int> pInt(new int(5)); unique_ptr<int> pInt2 = std::move(pInt); // 轉移所有權 //cout << *pInt << endl; // 出錯,pInt為空 cout << *pInt2 << endl; unique_ptr<int> pInt3(std::move(pInt2)); }
4、可以返回unique_ptr
unique_ptr不支持拷貝操作,但卻有一個例外:可以從函數中返回一個unique_ptr。
示例:
unique_ptr<int> clone(int p) { unique_ptr<int> pInt(new int(p)); return pInt; // 返回unique_ptr } int main() { int p = 5; unique_ptr<int> ret = clone(p); cout << *ret << endl; }
unique_ptr使用場景
1、為動態申請的資源提供異常安全保證
我們先來看看下面這一段代碼:
void Func() { int *p = new int(5); // ...(可能會拋出異常) delete p; }
這是我們傳統的寫法:當我們動態申請內存后,有可能我們接下來的代碼由于拋出異常或者提前退出(if語句)而沒有執行delete操作。
解決的方法是使用unique_ptr來管理動態內存,只要unique_ptr指針創建成功,其析構函數都會被調用。確保動態資源被釋放。
void Func() { unique_ptr<int> p(new int(5)); // ...(可能會拋出異常) }
2、返回函數內動態申請資源的所有權
示例如下:
unique_ptr<int> Func(int p) { unique_ptr<int> pInt(new int(p)); return pInt; // 返回unique_ptr } int main() { int p = 5; unique_ptr<int> ret = Func(p); cout << *ret << endl; // 函數結束后,自動釋放資源 }
3、在容器中保存指針
int main() { vector<unique_ptr<int>> vec; unique_ptr<int> p(new int(5)); vec.push_back(std::move(p)); // 使用移動語義 }
4、管理動態數組
標準庫提供了一個可以管理動態數組的unique_ptr版本。
int main() { unique_ptr<int[]> p(new int[5] {1, 2, 3, 4, 5}); p[0] = 0; // 重載了operator[] }
看完上述內容,是不是對C++11中的unique_ptr的詳細用法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。