一: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()< 欢迎分享,转载请注明来源:内存溢出
评论列表(0条)