一个weak_ptr提供对一个或多个shared_ptr实例拥有的对象的访问,但不参与引用计数。weak_ptr的主要使用场景,一是用于探查是否内存空间是否有效,用户可以通过expired()或者lock()来检测数据的有效性,以避免空指针。二是可以用于打破循环引用。c++20中的原子智能指针 智能指针的计数器是线程安全,但是其指向的对象的...
它可以指向shared_ptr所指向的对象,但是却不增加对象的引用计数。这样就有可能出现weak_ptr所指向的对象实际上已经被释放了的情况。因此,weak_ptr有一个lock函数,尝试取回一个指向对象的shared_ptr。 1 2 3 4 5 6 7 cout<<"test weak_ptr basic usage:"<<endl; auto p10=make_shared<int>(1024); weak_...
使用lock() 方法,如果 std::weak_ptr 过期则返回空的 std::shared_ptr。 std::shared_ptr<Widget> spw1 = wpw.lock(); // 如果 wpw 过期,spw1 将为空 1. 或者直接构造 std::shared_ptr,如果 std::weak_ptr 过期则抛出 std::bad_weak_ptr 异常。 try { std::shared_ptr<Widget> spw3(wpw); ...
}//p离开作用域后,它指向的内存会被自动释放shared_ptr<Test>use_hun2(intd){shared_ptr<Test> p = hun(d);//计数器为1returnp;//返回p时,计数器递增,为2}//离开作用域后,计数器递减,为1,因为不为0,所以不会释放intmain(){//test1 shared_ptr和unique_ptr都支持的操作/* //shared_ptr<Test> ...
1、如果你真的需要使用独有的资源(对象),使用shared_ptr而不是unique_ptr会使你的代码容易出现资源泄露和一些bug。 不易察觉的bug:有没有想过这种情况,如果有其他程序员无意间通过赋值给另一个共享指针而修改了你共享出来的资源/对象,而你却从没有预料到这种事情!
std::shared_ptr<int> sPtr(new int(5)); std::weak_ptr<int> wPtr = sPtr; //weak_ptr不会改变shared_ptr,但是会和shared_ptr的引用保持一致 std::shared_ptr<int> sPtr2 = wPtr.lock(); //wPtr.lock()后会改变shared_ptr的引用计数(+1)...
Alice->m_otherOne.lock()->m_name; // weak_ptr访问对象方式 1. 2. lock函数返回一个从weak_ptr构建的临时的shared_ptr,通过此shared_ptr我们可以访问对象。lock函数的调用含义相当于以下语句: expired() ? shared_ptr<T>() : shared_ptr<T>(*this) ...
1、shared_ptr智能指针的创建 shared_ptr 类模板中,提供了多种实用的构造函数,这里给读者列举了几个常用的构造函数(以构建指向 int 类型数据的智能指针为例)。 1) 通过如下 2 种方式,可以构造出 shared_ptr 类型的空智能指针: 注意,空的 shared_ptr 指针,其初始引用计数为 0,而不是 1。
如果类C没有正确实现这些函数,就会导致无法初始化shared_ptr。 类C的构造函数是私有的:shared_ptr需要通过调用类的构造函数来创建对象。如果类C的构造函数是私有的,那么无法从外部创建对象,也就无法初始化shared_ptr。 类C是一个抽象类或接口:shared_ptr只能管理完整的对象,而不能管理抽象类或接口。如果类C是一个...
weak_ptr引入可以解决shared_ptr交叉引用时无法释放资源的问题。 示例代码: #include<iostream>#include<memory>usingnamespacestd;classB;classA{public:A(){cout <<"A constructor ... "<< endl;} ~A(){cout <<"A destructor ..."<< endl;} ...