shared_ptr:
不能用物件指標獨立的初始化兩個智慧型指標
例子:
classtestsp
~testsp()
const
string&getstr()
void setstr(string
s)
void
print()
private
:
string
str;
};
使用:
testsp *dx = new testsp("123"
);shared_ptr
p3(dx);
shared_ptr
p4(dx);
//或者
shared_ptrp5(p3.get());
這樣做,每個智慧型指標內部計數其實都是1,在p3結束或手動reset後,該物件記憶體**了,p4和p5裡面的普通指標都變成了懸空指標,然後p4和p5結束時,還是回去對已經**了的記憶體呼叫delete,造成錯誤(編譯不出錯,執行會出錯)
要用多個指標指向同一塊記憶體,後面的智慧型指標要用前面的來初始化(通過智慧型指標類的拷貝構造或賦值運算子):
shared_ptrp6(p3); //這樣p3、p6內部計數都是2了
unique_ptr:
unique_ptr不能拷貝、賦值
如果需要把乙個unique_ptr的所有權:
例子:
testsp *dx = new testsp("123"
);unique_ptr
up1(dx);
unique_ptr
up2(new testsp("
456"
));up2 = std::move(up1);//
up2指向的"456"釋放,up2指向"123",up1置為null
up1.reset(up2.release());//
up2調release,up2置空但"123"沒有釋放,返回"123"的指標,up1重新繫結到"123"
up1.reset();//
up1去掉與"123"的繫結,"123"釋放,up1置空
weak_ptr:
不控制所指物件生存期
指向shared_ptr管理的物件,不引起shared_ptr引用計數改變,即使還有weak_ptr指向物件,shared_ptr計數為0時還是會釋放該物件。
兩個shared_ptr相互引用,則計數永遠不為0,造成死鎖而不釋放
C 11智慧型指標
本文介紹c 的四種智慧型指標,其中後三種是c 11新增加的,auto ptr已被棄用。要編譯c 11,需要安裝g 4.8 sudo add apt repository ppa ubuntu toolchain r test sudo apt get update sudo apt get inst...
c 11 智慧型指標
如果在程式中使用new從堆 自由儲存區 分配記憶體,等到不需要時,應使用delete將其釋放。c 引入了智慧型指標auto ptr,以幫助自動完成這個過程。c 11摒棄了auto ptr,並新增了三種智慧型指標 unique ptr,shared ptr,weak ptr。一.auto ptr,un...
c 11 智慧型指標
首先來看shared ptr,先貼一小部分vs2013裡的實現 template class shared ptr template class shared ptr public ptr base ty template explicit shared ptr ux px template cla...