shared

shared,第1张

shared

一:shared_ptr
基本概念:
shared_ptr通过一个饮用计数,共享一个对象,shared_ptr为了解决unique_ptr在对象所有权上的局限性,在使用引用计数的机制上提供了可以共享对象所有权的职能指针,当然这需要额外的开销。当引用计数为0时,该对象没有被使用,可以进行析构。

潜在问题:
引用计数会带来循环引用的问题,会导致堆里的内存无法被回收导致内存泄漏。
如下图所示:
如果某一时刻pA指针指向了B对象,而PB指针指向了对象A。如果想要释放A对象内存,A对象发现自己内部有指针指向B对象,所以需要先释放B对象,再释放A对象才能不会导致程序出错。而B对象也存在相同的问题,都需要先释放对方对象导致了循环引用,那么为了解决这个问题,我们引入了weak_ptr。

二:weak_ptr
基本概念:
weak_ptr被设计为与shared_ptr共同工作,用一种观察者模式工作。作用时协助shared_ptr工作,可获得资源的观测权,像旁观者那样观察资源的使用情况。观察者意味着weak_ptr只对shared_ptr进行引用,而不改变其引用计数,当被观察的shared_ptr失效后相应的weak_ptr也会失效。

下面看下shared_ptr的简单用例

#include 
#include 
using namespace std;

int main(int argc, const char * argv[])
{
    // insert code here...
    //shared_ptr:shared_ptr代表的是共享所有权,即多个shared_ptr可以共享一块内存
    auto wA = shared_ptr(new int(20));
    {
        auto wA2 = wA;
        cout << ((wA2.get()!=nullptr)?(*wA2.get()):-1)<(30);
    auto wAA2 = std::move(wAA); //此时wAA等于nullptr,wAA2.use_count()等于1
    cout<<((wAA.get()!=nullptr)?(*wAA.get()):-1)< 

下面看下针对于weak_ptr所做的观察工作用例

#include 
#include 

using namespace std;

struct B;
struct A
{
    shared_ptr pb;
    ~A()
    {
        cout <<"~A()"< pb;
    ~AW()
    {
        cout <<"~AW()"<pb = tB;
    tB->pa = tA;
    cout < tB(new BW());
    cout <pb = tB;
    tB->pa = tA;
    cout << tA.use_count()<					
										


					

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5155650.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-18
下一篇 2022-11-18

发表评论

登录后才能评论

评论列表(0条)

保存