C++11 std::shared_ptr總結(jié)與使用示例代碼詳解
最近看代碼,智能指針用的比較多,自己平時(shí)用的少,周末自己總結(jié)總結(jié)。方便后續(xù)使用。
std::shared_ptr大概總結(jié)有以下幾點(diǎn):
(1) 智能指針主要的用途就是方便資源的管理,自動(dòng)釋放沒(méi)有指針引用的資源。
(2) 使用引用計(jì)數(shù)來(lái)標(biāo)識(shí)是否有多余指針指向該資源。(注意,shart_ptr本身指針會(huì)占1個(gè)引用)
(3) 在賦值操作中, 原來(lái)資源的引用計(jì)數(shù)會(huì)減一,新指向的資源引用計(jì)數(shù)會(huì)加一。
std::shared_ptr<Test> p1(new Test); std::shared_ptr<Test> p2(new Test); p1 = p2;
(4) 引用計(jì)數(shù)加一/減一操作是原子性的,所以線程安全的。
(5) make_shared要優(yōu)于使用new,make_shared可以一次將需要內(nèi)存分配好。
std::shared_ptr<Test> p = std::make_shared<Test>(); std::shared_ptr<Test> p(new Test);
(6)std::shared_ptr的大小是原始指針的兩倍,因?yàn)樗膬?nèi)部有一個(gè)原始指針指向資源,同時(shí)有個(gè)指針指向引用計(jì)數(shù)。
(7) 引用計(jì)數(shù)是分配在動(dòng)態(tài)分配的,std::shared_ptr支持拷貝,新的指針獲可以獲取前引用計(jì)數(shù)個(gè)數(shù)。
下面是一段示例代碼,注釋詳細(xì):
include <iostream>
#include <memory>
#include <thread>
#include <chrono>
#include <mutex>
struct Test
{
Test() { std::cout << " Test::Test()\n"; }
~Test() { std::cout << " Test::~Test()\n"; }
};
//線程函數(shù)
void thr(std::shared_ptr<Test> p)
{
//線程暫停1s
std::this_thread::sleep_for(std::chrono::seconds(1));
//賦值操作, shared_ptr引用計(jì)數(shù)use_cont加1(c++11中是原子操作)
std::shared_ptr<Test> lp = p;
{
//static變量(單例模式),多線程同步用
static std::mutex io_mutex;
//std::lock_guard加鎖
std::lock_guard<std::mutex> lk(io_mutex);
std::cout << "local pointer in a thread:\n"
<< " lp.get() = " << lp.get()
<< ", lp.use_count() = " << lp.use_count() << '\n';
}
}
int main()
{
//使用make_shared一次分配好需要內(nèi)存
std::shared_ptr<Test> p = std::make_shared<Test>();
//std::shared_ptr<Test> p(new Test);
std::cout << "Created a shared Test\n"
<< " p.get() = " << p.get()
<< ", p.use_count() = " << p.use_count() << '\n';
//創(chuàng)建三個(gè)線程,t1,t2,t3
//形參作為拷貝, 引用計(jì)數(shù)也會(huì)加1
std::thread t1(thr, p), t2(thr, p), t3(thr, p);
std::cout << "Shared ownership between 3 threads and released\n"
<< "ownership from main:\n"
<< " p.get() = " << p.get()
<< ", p.use_count() = " << p.use_count() << '\n';
//等待結(jié)束
t1.join(); t2.join(); t3.join();
std::cout << "All threads completed, the last one deleted\n";
return 0;
}
編譯執(zhí)行:

參考:
c++實(shí)現(xiàn)加載so動(dòng)態(tài)庫(kù)中的資源 http://www.dhdzp.com/article/101744.htm
C++ 智能指針深入解析 http://www.dhdzp.com/article/39793.htm
C++11 智能指針之shared_ptr代碼詳解 http://www.dhdzp.com/article/188233.htm
總結(jié)
到此這篇關(guān)于C++11 std::shared_ptr總結(jié)與使用示例代碼詳解的文章就介紹到這了,更多相關(guān)C++11 std::shared_ptr內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C++特性之智能指針shared_ptr詳解
- C++ Boost shared_ptr共享指針詳細(xì)講解
- C++簡(jiǎn)單實(shí)現(xiàn)shared_ptr的代碼
- C++中Boost的智能指針shared_ptr
- C++智能指針之shared_ptr的具體使用
- C++智能指針之shared_ptr詳解
- C++智能指針shared_ptr
- C++11中的智能指針shared_ptr、weak_ptr源碼解析
- 深入學(xué)習(xí)C++智能指針之shared_ptr與右值引用的方法
- C++11 智能指針之shared_ptr代碼詳解
- C++共享智能指針shared_ptr的實(shí)現(xiàn)
相關(guān)文章
Opencv2.4.9函數(shù)HoughLinesP分析
這篇文章主要為大家詳細(xì)介紹了Opencv2.4.9函數(shù)HoughLinesP,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
緩存處理函數(shù)storageKeySuffix操作示例解析
這篇文章主要介紹了淺析緩存處理函數(shù)storageKeySuffix操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
Linux頁(yè)面置換算法的C語(yǔ)言實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Linux頁(yè)面置換算法的C語(yǔ)言實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
C語(yǔ)言實(shí)現(xiàn)帶頭雙向環(huán)形鏈表
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)帶頭雙向環(huán)形鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
VS2019創(chuàng)建C++工程的的實(shí)現(xiàn)步驟
本文主要介紹了VS2019創(chuàng)建C++工程步驟,包含新建項(xiàng)目、編輯文件、配置源文件目錄、編譯鏈接、輸出文件、設(shè)置斷點(diǎn)調(diào)試,具有一定的參考價(jià)值,感興趣的可以了解一下2024-12-12
簡(jiǎn)要對(duì)比C語(yǔ)言中的dup()函數(shù)和dup2()函數(shù)
這篇文章主要介紹了簡(jiǎn)要對(duì)比C語(yǔ)言中的dup()函數(shù)和dup2()函數(shù),是C語(yǔ)言入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-08-08
C語(yǔ)言實(shí)現(xiàn)維吉尼亞密碼的示例代碼
維吉尼亞密碼(又譯維熱納爾密碼)是使用一系列凱撒密碼組成密碼字母表的加密算法,屬于多表密碼的一種簡(jiǎn)單形式。本文將用C語(yǔ)言實(shí)現(xiàn)維吉尼亞密碼,需要的可以參考一下2022-11-11
c語(yǔ)言輸出字符串中最大對(duì)稱子串長(zhǎng)度的3種解決方案
這篇文章主要介紹了c語(yǔ)言輸出字符串中最大對(duì)稱子串長(zhǎng)度的3種解決方案,需要的朋友可以參考下2014-03-03

