最近学习网络变成发现一些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指针,在外部调用时才会统计总的引用计数。