c++ shared_ptr指针实现

#include <stdio.h>
#include <stdlib.h>
#include <string>


template<typename T>
class shared_ptr;


template<typename TT>
shared_ptr<TT>& make_shared(TT s)
{
shared_ptr<TT>* ss = new shared_ptr<TT>(new TT(s));
--*(ss->m_count);
printf("%d\n",*(ss->m_count));
return *ss;
}


template<typename T>
class shared_ptr
{
private:
T* m_ptr;
int* m_count;
public:
shared_ptr();
explicit shared_ptr(T* s);          //用explicit 修饰的构造函数,不具有隐式转换功能,只能构造对象显示调用,(不能将T* 隐式转换成临时无名的shared_ptr对象)
shared_ptr(const shared_ptr<T>&);
~shared_ptr();


T* get();
int use_count();


T* operator->();//特别的运算符,它是指向自己成员的,所以不需要参数,且由于不能与原运算符功能冲突,规定它只能重载作为函数成员
T operator*();
shared_ptr<T>& operator=(const shared_ptr<T>&s);
bool operator==(const shared_ptr<T>&s);


//friend shared_ptr<T>make_shared<T>(T s);//绑定的有元函数模板,声明时,需要在函数名后加上<> ,但是实现不需要了,且函数模板必须先存在
//可以写成
template<typename TT>
friend shared_ptr<TT>& make_shared(TT s);  //非绑定的有元函数模板,可以在之后实现函数模板
};


template<typename T>
T shared_ptr<T>::operator*()
{
if(m_ptr!=NULL)
return *m_ptr;
}


template<typename T>
T* shared_ptr<T>::operator->()
{
if(m_ptr!= NULL)
return m_prt;
else
return NULL;
}


template<typename T>
shared_ptr<T>& shared_ptr<T>::operator=(const shared_ptr<T>&s)
{
if(s.m_ptr==NULL)
{
m_ptr = NULL;
(*m_count)--;
if(*m_count == 1)
{
delete m_count;
delete m_ptr;
}
m_count = s.m_count;
}
else
{
m_ptr = s.m_ptr;
m_count = s.m_count;
(*m_count)++;
}
return *this;
}


template<typename T>
shared_ptr<T>::shared_ptr()
{
m_ptr=NULL;
m_count = new int(0);
}


template<typename T>
shared_ptr<T>::shared_ptr(T*s)
{
if(s==NULL)
{
m_ptr=NULL;
m_count = new int(0);
}
else
{
m_ptr = s;
m_count = new int(1);
}
}


template<typename T>
shared_ptr<T>::shared_ptr(const shared_ptr<T>& s)
{
if(s.m_ptr == NULL)
{
m_ptr = NULL;
m_count = s.m_count;
}
else
{
m_ptr = s.m_ptr;
m_count = s.m_count;
(*m_count)++;
}
}


template<typename T>
shared_ptr<T>::~shared_ptr()
{
if(*m_count == 1)
{delete m_ptr;
delete m_count;
}
else if(*m_count == 0)
{

}
else
{
(*m_count)--;
}
}


template<typename T>
T* shared_ptr<T>::get()
{
return m_ptr;
}


template<typename T>
int shared_ptr<T>::use_count()
{
return *m_count;
}




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的 shared_ptr 的代码实现: ```cpp template<typename T> class shared_ptr { public: shared_ptr() : ptr(nullptr), ref_count(nullptr) {} shared_ptr(T* p) : ptr(p), ref_count(new int(1)) {} shared_ptr(const shared_ptr& other) : ptr(other.ptr), ref_count(other.ref_count) { if (ref_count) { ++(*ref_count); } } shared_ptr& operator=(const shared_ptr& other) { if (this != &other) { release(); ptr = other.ptr; ref_count = other.ref_count; if (ref_count) { ++(*ref_count); } } return *this; } ~shared_ptr() { release(); } T& operator*() const { return *ptr; } T* operator->() const { return ptr; } operator bool() const { return ptr != nullptr; } T* get() const { return ptr; } private: void release() { if (ref_count) { --(*ref_count); if (*ref_count == 0) { delete ptr; delete ref_count; } ptr = nullptr; ref_count = nullptr; } } T* ptr; int* ref_count; }; ``` 在这个实现中,我们使用一个指针 `ptr` 来保存所指向的对象,使用一个指针 `ref_count` 来保存指向该对象的共享指针数量。当一个新的 shared_ptr 对象创建时,我们将 `ref_count` 初始化为 1,表示当前只有一个 shared_ptr 对象指向该对象。当我们拷贝一个 shared_ptr 对象时,我们将 `ref_count` 增加 1,并与原对象共享同一个指针。当一个 shared_ptr 对象被销毁时,我们将 `ref_count` 减 1,如果此时 `ref_count` 的值为 0,表示没有任何 shared_ptr 对象指向该对象了,我们就可以释放该对象的内存和 `ref_count` 的内存了。 此外,我们还实现了 `operator*` 和 `operator->` 来方便访问所指向的对象,实现了 `operator bool` 来判断 shared_ptr 是否为空,实现了 `get` 函数来获取指向的对象的指针

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值