智能指针

关键点##

RAII机制

C++操作符重载

参考链接##

C++11智能指针之unique_ptr

shared_ptr

shared_ptr的几点注意点

智能指针weak_ptr

cpluscplus

unique_ptr智能指针##

生命周期###

unique_ptr生命周期,与普通的数据类型相同,一旦离开作用域,如果其指向对象,
就会将指向的对象进行销毁。

unique_ptr特点在于其“独占”的特点,同一时刻
unique_ptr指向的对象只能有一个引用,不能存在多个unique_ptr指向同一个对象

基本操作###

//后期绑定
unique_ptr ui;
ui.reset(new int(1));
//创建时动态绑定
unique_ptr ui2(new int(1));
//释放所有权
int* pi = ui2.release();
//转移所有权
unique_ptr us(new string("abc"));
unique_ptr us2 = std::move(us);
//主动销毁
us2 = nullptr

shared_ptr##

生命周期###

shared_ptr生命周期在离开作用域时,会将其指向对象的引用计数减一,
如果发现引用计数已经归〇,那么将会把其引用的对象进行进行销毁。

shared_ptr的特点在于“引用计数”,每当有一个shared_ptr
指针指向相同的对象的时候,将会把引用计数增加1,每当指向对象的shared_ptr被销毁时,
将会把引用计数减少1,当引用计数减少为0时,将会把对象销毁。

基本操作

//创建的时动态绑定
shared_ptr sp(new int(10));
//通过拷贝
shared_ptr sp1 = sp;
//停止引用对象
sp.reset();
//销毁释放
sp1 = nullptr;

注意###

由于其使用引用计数的方式进行引用对象的释放,所以可能存在环状链式结构造成内存的泄露。
这种时候需要使用另一个智能指针weak_ptr解决这种情况。c++无法想java那样自动判断并
释放环状链式结构,所以在使用上还是得需要小心处理。

由于其内部加减引用计数不是线程安全,所以在多线程使用时需要自己添加加锁操作以保证
其引用计数的正确性。

weak_ptr##

生命周期###

严格来说,weak_ptr并不像shared_ptr以及unique_ptr一样存在生命周期这总说法,因为
其内部不进行引用对象的释放,也无法直接进行引用对象的解引用以及->操作。其如果需要
进行引用对象的操作,需要使用lock函数获取一个shared_ptr指针,然后性shared_ptr一
样进行使用。

weak_ptr的特点在于“辅助”shared_ptr指针的使用,其最大
的作用在于解决shared_ptr环状引用的问题。

基本操作

//引用对象
shared_ptr sp(new int(1));
weak_ptr wp(sp);
//判断是否失效
if (wp.expired())
{
    //未失效
    //获取一个Shared_ptr对象进行使用
    shared_ptr sp1 = wp.lock();
    *sp1 = 0;
}
else
{
    //已经失效
}

你可能感兴趣的:(智能指针)