boost中的shared_ptr

1 篇文章 0 订阅
1 篇文章 0 订阅
看了一下boost中的shared_ptr的源码,简化出了如下的版本,帮助理解shared_ptr的工作原理
class sp_counted_base{
public:
long use_count;

public:
sp_counted_base():use_count(1){}
void add_ref_copy(){
    ++use_count;//此处是原子操作,这里简化了
}
virtual void dispose()=0;
void release(){
    if((--use_count)==0)//此处也是原子操作,这里简化了
    {
        dispose();
        delete this;  
    }
}
};

template <class X>
class sp_counted_impl_p : public sp_counted_base{
private:
  X *px_;
public:
sp_counted_impl_p(X *px):px_(px){}
virtual void dispose(){
  delete px_;
}
};

class shared_count{
public:
sp_counted_base *pi;
public:
shared_count():pi(0){}
shared_count(shared_count const &r):pi(r.pi){
    pi->add_ref_copy();
}

template <class Y>
shared_count(Y *y):pi(0){
try{
    pi=new sp_counted_impl_p<Y>(y);
}catch(...){
    delete y;
}
}
void swap(shared_count &r){
sp_counted_base *tmp=r.pi;
r.pi=pi;
pi=tmp;
}
~shared_count(){
if(pi!=0)
    pi->release();
}
};

template <class T>
class shared_ptr{
public:
T *px;
shared_count pn;

public:
shared_ptr():px(0),pn(){}

template <class Y>
shared_ptr(Y *p):px(p),pn(){
shared_count(p).swap(pn);
}
shared_ptr(shared_ptr const &r):px(r.px),pn(r.pn){}
};

class testClass{
public:
~testClass(){
std::cout<<"testClass 被析构了"<<std::endl;
}
};

void test(){
shared_ptr<testClass> sp1(new testClass);
std::cout<<(sp1.pn.pi->use_count)<<std::endl;
shared_ptr<testClass> sp2(sp1);
std::cout<<(sp1.pn.pi->use_count)<<" "<<(sp2.pn.pi->use_count)<<std::endl;
}

最终的输出结果是

1
2 2
testClass被析构了

从上面的代码可以看出,shared_ptr虽然持有对象的指针,但是并不负责delete,delete的发生是在shared_ptr被销毁时它内部的shared_count pn负责的,
pn的析构函数判断pi是否为空指针,如果不是,就调用pi的release函数,sp_counted_base先将计数器减一,如果是0,就调用dispose函数,dispoase的实现是在sp_counted_impl_p 中实现的,最终由dispose函数负责delete。同时,release函数将delete自身,因为pi=new sp_counted_impl_p(y);为了避免内存泄露,也要删除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值