关键点##
RAII机制
C++操作符重载
参考链接##
unique_ptr智能指针##
生命周期###
unique_ptr生命周期,与普通的数据类型相同,一旦离开作用域,如果其指向对象,
就会将指向的对象进行销毁。
unique_ptr特点在于其“独占”的特点,同一时刻
unique_ptr指向的对象只能有一个引用,不能存在多个unique_ptr指向同一个对象
。
基本操作###
//后期绑定
unique_ptr<int> ui;
ui.reset(new int(1));
//创建时动态绑定
unique_ptr<int> ui2(new int(1));
//释放所有权
int* pi = ui2.release();
//转移所有权
unique_ptr<string> us(new string("abc"));
unique_ptr<string> us2 = std::move(us);
//主动销毁
us2 = nullptr
shared_ptr##
生命周期###
shared_ptr生命周期在离开作用域时,会将其指向对象的引用计数减一,
如果发现引用计数已经归〇,那么将会把其引用的对象进行进行销毁。
shared_ptr的特点在于“引用计数”,每当有一个shared_ptr
指针指向相同的对象的时候,将会把引用计数增加1,每当指向对象的shared_ptr被销毁时,
将会把引用计数减少1,当引用计数减少为0时,将会把对象销毁。
基本操作
//创建的时动态绑定
shared_ptr<int> sp(new int(10));
//通过拷贝
shared_ptr<int> 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<int> sp(new int(1));
weak_ptr<int> wp(sp);
//判断是否失效
if (wp.expired())
{
//未失效
//获取一个Shared_ptr对象进行使用
shared_ptr<int> sp1 = wp.lock();
*sp1 = 0;
}
else
{
//已经失效
}