一、auto_ptr模板
auto_ptr與shared_ptr、unique_ptr都定義了類似指針的對象,可以將new到的地址賦給這一對象,當(dāng)智能指針過期時,析構(gòu)函數(shù)會調(diào)用delete函數(shù),對象將被銷毀,由此內(nèi)存可以自動被釋放。
二、shared_ptr模板
先看代碼:
auto_ptr p1 (new string("hello world!");
auto_ptr p2;
p2 = p1;
在以上代碼中,p1與p2指向同一對象,常規(guī)指針在釋放內(nèi)存時,系統(tǒng)會嘗試刪除同一對象兩次。在auto_ptr中,對象的所有權(quán)會歸于p2,p1將會變?yōu)橐爸羔?。shared_ptr則允許多個指針指向同一個對象,每多一個指針指向,計數(shù)器就會+1,同樣在釋放的時候,當(dāng)數(shù)值減為0的時候即最后一個指針過期的時候才會調(diào)用delete函數(shù)。
三、unique_ptr模板
同樣為了避免多個指針指向,unique_ptr嚴(yán)格了所有權(quán)的概念,即我的就我的,不允許他人指向(如代碼段二中,采用unique_ptr編輯將會報錯,而原代碼會編譯通過但可能造成崩潰)。
四、總結(jié)
需要多個指針指向一個對象時可使用shared_ptr,如指針數(shù)組。不需要多個指針指向一個對象可使用uniq_ptr,uniqu_ptr比auto_ptr更加安全(編譯報錯遠(yuǎn)比程序崩潰好得多)。
if(failed(l_hr))
{
return l_hr;
}
//dosomething of itestcomptr
couninitialize();
}
初看這段代碼是沒有任何問題的,但是運行還是會崩潰.如果我們在
coinitialize(null);下行加上"{"與couninitialize();上行加上"}"就不會出錯了.為什么呢?
原因在于原來的coinitialize所開的套間在couninitialize();后已經(jīng)被關(guān)閉.
而智能指針的組件對象卻并沒有釋放,直到程序調(diào)用ccomptr<itestcomptr>;的析構(gòu)函數(shù)時才調(diào)用
itestcomptr的release方法,但是這時候,套間已經(jīng)不在了,所以導(dǎo)致了程序的崩潰.在組件
的生命周期很短的時候,智能指針的使用基本是無害的,并且有時是非常方便的.
所以在使用智能指針時有以下建議:
1. 當(dāng)對象的生命周期很長要小心使用.
2. 當(dāng)對象的生命周期不確定時不要使用.
3. 千萬不要使用全局的智能指針.
if(failed(l_hr)) { return l_hr; } //dosomething of itestcomptr couninitialize(); } 初看這段代碼是沒有任何問題的,但是運行還是會崩潰.如果我們在 coinitialize(null);下行加上"{"與couninitialize();上行加上"}"就不會出錯了.為什么呢? 原因在于原來的coinitialize所開的套間在couninitialize();后已經(jīng)被關(guān)閉. 而智能指針的組件對象卻并沒有釋放,直到程序調(diào)用ccomptr的析構(gòu)函數(shù)時才調(diào)用 itestcomptr的release方法,但是這時候,套間已經(jīng)不在了,所以導(dǎo)致了程序的崩潰.在組件 的生命周期很短的時候,智能指針的使用基本是無害的,并且有時是非常方便的. 所以在使用智能指針時有以下建議: 1. 當(dāng)對象的生命周期很長要小心使用. 2. 當(dāng)對象的生命周期不確定時不要使用. 3. 千萬不要使用全局的智能指針.。
聲明:本網(wǎng)站尊重并保護(hù)知識產(chǎn)權(quán),根據(jù)《信息網(wǎng)絡(luò)傳播權(quán)保護(hù)條例》,如果我們轉(zhuǎn)載的作品侵犯了您的權(quán)利,請在一個月內(nèi)通知我們,我們會及時刪除。
蜀ICP備2020033479號-4 Copyright ? 2016 學(xué)習(xí)鳥. 頁面生成時間:2.679秒