一、weak_ptr概述:weak_ptr辅助shared_ptr进行工作
weak“弱",反义词”强“
强值得就是shared_ptr,弱指的就是weak_ptr;
weak_ptr:也是类模板,也是个智能指针。这个智能指针指向一个由shared_ptr管理的对象,但是weak_ptr不控制指向对象的生存期。
换句话来说,将weak_ptr绑定到shared_ptr上并不会改变shared_ptr的引用计数(更确切的说,weak_ptr的构造和析构不会增加或减少所指对象的引用技术)
当shared_ptr需要释放所指定对象的时候照常释放,不管是否有weak_ptr指向该对象。weak意思是”弱“
能力弱(弱共享/弱引用:共享其他的shared_ptr所指向的对象),控制不了所指对象的生命期
这个弱引用(weak_ptr)的作用:大家可以立即成监视shared_ptr(强引用)的生命周期用的,是一种对shared_ptr的扩充。
weak_ptr不是一种独立的智能指针,不能用来操作所指向的资源,所以它看起来像一个shared_ptr的助手(旁观者)这种感觉
weak_ptr能够监视到它所指向的对象是否存在
1.1weak_ptr的创建
#include <iostream>
#include <memory>
using namespace std;
int main() {
// 我们创建weak_ptr的时候,一般是用一个shared_ptr来初始化
auto pi = make_shared<int>(100); // shared_ptr
weak_ptr<int> piw(pi);
// piw弱共享pi,pi引用计数(强引用计数)不改变,但是弱引用计数会从变1)
// 强引用技术才能决定对象的生命期;弱引用技术对对象生命期没有影响
weak_ptr<int> piw2;
piw2 = pi; // pi是一个shared_ptr,赋值给一个weak_ptr,两者指向同一个内存对象
weak_ptr<int> piw3;
piw3 = piw2; // 把weak_ptr赋给另外一个weak_ptr,现在pi是一个强引用,piw和piw2,piw3是两个弱引用
cout << pi.use_count() << endl;
pi.reset();
// 因为pi是唯一指向该对象的强引用智能指针,所以reset会释放pi所指向的对象,同时将pi置空
auto pi2 = piw.lock(); // pi2是一个shared_ptr
if (pi2 != nullptr) {
*pi2 = 12;
} else {
cout << "很遗憾,lock()失败" << endl;
}
// 总结:weak_ptr能够判断所指向的对象是否存在,这种能力
return 0;
}