最近学习网络变成发现一些C++源码库中封装对象时会公有继承enable_shared_from_this;
用一个案例进行说明,案例代码如下:
#include <iostream>
#include <memory>
#include <stdio.h>using namespace std;class C : public enable_shared_from_this<C>
{public:shared_ptr<C> f1(){return shared_from_this();}C* f2(){ return this;}
};int main(){shared_ptr<C> p1(new C);printf("p1 count: %d; p1 addr:%x \n", p1.use_count(), p1.get());// 调用shared_from_this()返回指向自身的shared_ptr。shared_ptr<C> p2 = p1->f1();printf("p2 count: %d; p2 addr:%x \n", p2.use_count(), p2.get());// 弱引用不增加共享指针计数weak_ptr<C> p4 = p1->f1();printf("p4 count: %d; p4 addr:%x \n", p4.use_count(), p4.lock().get());// 将弱引用提升为共享指针再被引用计数增加shared_ptr<C> p5 = p4.lock();printf("p5 count: %d; p5 addr:%x \n", p5.use_count(), p5.get());printf("----------------没有用 shared_from_this()----------------\n");// 调用this指针等于重新定义了一个shared_ptr,计数为1。shared_ptr<C> p3(p1->f2());printf("p3 count: %d; p3 addr:%x \n", p3.use_count(), p3.get());return 0;
}
程序执行结果如下:
由案例代码可知,只有当调用shared_from_this函数返回指向该对象的shared_ptr指针,在外部调用时才会统计总的引用计数。