C++11智能指針中的 unique_ptr實(shí)例詳解
在前面一篇文章中,我們了解了 C++11 中引入的智能指針之一 shared_ptr 和 weak_ptr ,今天,我們來介紹一下另一種智能指針 unique_ptr 。
往期文章參考:
【C++11新特性】 C++11 智能指針之shared_ptr
unique_ptr介紹
unique是獨(dú)特的、唯一的意思,故名思議,unique_ptr可以“獨(dú)占”地?fù)碛兴赶虻膶ο?,它提供一種嚴(yán)格意義上的所有權(quán)。
這一點(diǎn)和我們前面介紹的 shared_ptr 類型指針有很大的不同:shared_ptr 允許多個(gè)指針指向同一對象,而 unique_ptr 在某一時(shí)刻只能有一個(gè)指針指向該對象。
unique_ptr 保存指向某個(gè)對象的指針,當(dāng)它本身被刪除或者離開其作用域時(shí)會(huì)自動(dòng)釋放其指向?qū)ο笏加玫馁Y源。
1、如何創(chuàng)建unique_ptr
unique_ptr 不像shared_ptr一樣擁有標(biāo)準(zhǔn)庫函數(shù)make_shared來創(chuàng)建一個(gè)shared_ptr實(shí)例。
要想創(chuàng)建一個(gè) unique_ptr,我們需要將一個(gè) new 操作符返回的指針傳遞給unique_ptr的構(gòu)造函數(shù)。
示例:
int main() {
// 創(chuàng)建一個(gè)unique_ptr實(shí)例
unique_ptr<int> pInt(new int(5));
cout << *pInt;
}
2、無法進(jìn)行復(fù)制構(gòu)造和賦值操作
unique_ptr沒有 copy 構(gòu)造函數(shù),不支持普通的拷貝和賦值操作。
示例:
int main() {
// 創(chuàng)建一個(gè)unique_ptr實(shí)例
unique_ptr<int> pInt(new int(5));
unique_ptr<int> pInt2(pInt); // 報(bào)錯(cuò)
unique_ptr<int> pInt3 = pInt; // 報(bào)錯(cuò)
}
3、可以進(jìn)行移動(dòng)構(gòu)造和移動(dòng)賦值操作
unique_ptr雖然沒有支持普通的拷貝和賦值操作,但卻提供了一種移動(dòng)機(jī)制來將指針的所有權(quán)從一個(gè)unique_ptr轉(zhuǎn)移給另一個(gè)unique_ptr。
如果需要轉(zhuǎn)移所有權(quán),可以使用std::move()函數(shù)。
示例:
int main() {
unique_ptr<int> pInt(new int(5));
unique_ptr<int> pInt2 = std::move(pInt); // 轉(zhuǎn)移所有權(quán)
//cout << *pInt << endl; // 出錯(cuò),pInt為空
cout << *pInt2 << endl;
unique_ptr<int> pInt3(std::move(pInt2));
}
4、可以返回unique_ptr
unique_ptr不支持拷貝操作,但卻有一個(gè)例外:可以從函數(shù)中返回一個(gè)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、為動(dòng)態(tài)申請的資源提供異常安全保證
我們先來看看下面這一段代碼:
void Func()
{
int *p = new int(5);
// ...(可能會(huì)拋出異常)
delete p;
}
這是我們傳統(tǒng)的寫法:當(dāng)我們動(dòng)態(tài)申請內(nèi)存后,有可能我們接下來的代碼由于拋出異?;蛘咛崆巴顺觯╥f語句)而沒有執(zhí)行delete操作。
解決的方法是使用unique_ptr來管理動(dòng)態(tài)內(nèi)存,只要unique_ptr指針創(chuàng)建成功,其析構(gòu)函數(shù)都會(huì)被調(diào)用。確保動(dòng)態(tài)資源被釋放。
void Func()
{
unique_ptr<int> p(new int(5));
// ...(可能會(huì)拋出異常)
}
2、返回函數(shù)內(nèi)動(dòng)態(tài)申請資源的所有權(quán)
示例如下:
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;
// 函數(shù)結(jié)束后,自動(dòng)釋放資源
}
3、在容器中保存指針
int main() {
vector<unique_ptr<int>> vec;
unique_ptr<int> p(new int(5));
vec.push_back(std::move(p)); // 使用移動(dòng)語義
}
4、管理動(dòng)態(tài)數(shù)組
標(biāo)準(zhǔn)庫提供了一個(gè)可以管理動(dòng)態(tài)數(shù)組的unique_ptr版本。
int main() {
unique_ptr<int[]> p(new int[5] {1, 2, 3, 4, 5});
p[0] = 0; // 重載了operator[]
}
總結(jié)
到此這篇關(guān)于C++11智能指針中的 unique_ptr實(shí)例詳解的文章就介紹到這了,更多相關(guān)C++11智能指針unique_ptr內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用C++和Crypto++庫實(shí)現(xiàn)AES加密與解密
在這篇博客中,我們將深入探討如何利用C++和Crypto++庫實(shí)現(xiàn)高效且安全的AES加密與解密機(jī)制,Crypto++是一款高度認(rèn)可的免費(fèi)C++類庫,文中通過代碼示例介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-01-01
C語言實(shí)現(xiàn)求解最小公倍數(shù)的算法示例
這篇文章主要為大家介紹了C語言如何實(shí)現(xiàn)求解任意兩個(gè)正整數(shù)的最小公倍數(shù),文中采用了窮舉法和定理法。感興趣的小伙伴快來跟隨小編一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12
C++編程中用put輸出單個(gè)字符和cin輸入流的用法
這篇文章主要介紹了C++編程中用put輸出單個(gè)字符和cin輸入流的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09
Qt私有信號(hào)實(shí)現(xiàn)(private signal)
在使用Qt信號(hào)槽機(jī)制的時(shí)候,有時(shí)候我們需要一個(gè)信號(hào)只能由類內(nèi)發(fā)出,而不允許使用該類對象的用戶發(fā)出,此時(shí)就需要私有信號(hào)的支持,本文主要介紹了Qt私有信號(hào)實(shí)現(xiàn)(private signal),感興趣的可以了解一下2023-10-10
用c++實(shí)現(xiàn)將文本每個(gè)單詞首字母轉(zhuǎn)換為大寫
本篇文章是對用c++實(shí)現(xiàn)將文本每個(gè)單詞首字母轉(zhuǎn)換為大寫的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C++的動(dòng)態(tài)內(nèi)存管理你真的了解嗎
這篇文章主要為大家詳細(xì)介紹了C++的動(dòng)態(tài)內(nèi)存管理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02
C語言超詳細(xì)講解數(shù)據(jù)結(jié)構(gòu)中雙向帶頭循環(huán)鏈表
帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用在單獨(dú)存儲(chǔ)數(shù)據(jù)。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個(gè)結(jié)構(gòu)雖然結(jié)構(gòu)復(fù)雜,但是使用代碼實(shí)現(xiàn)以后會(huì)發(fā)現(xiàn)結(jié)構(gòu)會(huì)帶來很多優(yōu)勢,實(shí)現(xiàn)反而簡單2022-04-04

