标签:应对 net 模板类 type article lse 析构函数 ons 指针
引自:https://blog.csdn.net/man_sion/article/details/77196766
//模板类作为友元时要先有声明
template <typename T>
class SmartPtr;
//辅助类
template <typename T>
class RefPtr
{
private:
//该类成员访问权限全部为private,因为不想让用户直接使用该类
friend class SmartPtr<T>; //定义智能指针类为友元,因为智能指针类需要直接操纵辅助类
//构造函数的参数为基础对象的指针
RefPtr(T *ptr):p(ptr), count(1){}
//析构函数
~RefPtr() {
delete p;
}
//引用计数
int count;
//基础对象指针
T *p;
};
//智能指针类
template <typename T>
class SmartPtr
{
public:
//构造函数
SmartPtr(T *ptr) :rp(new RefPtr<T>(ptr))
{}
//拷贝构造函数
SmartPtr(const SmartPtr<T> &sp):rp(sp.rp)
{
++rp->count;
}
//重载赋值操作符
SmartPtr& operator=(const SmartPtr<T>& rhs)
{
++rhs.rp->count; //首先将右操作数引用计数加1,
if (--rp->count == 0) //然后将引用计数减1,可以应对自赋值
delete rp;
rp = rhs.rp;
return *this;
}
//重载*操作符
T & operator *()
{
return *(rp->p);
}
//重载->操作符
T* operator ->()
{
return rp->p;
}
//析构函数
~SmartPtr()
{
if (--rp->count == 0) { //当引用计数减为 0 时,删除辅助类对象指针,从而删除基础对象
delete rp;
} else {
cout << "还有" << rp->count << "个指针指向基础对象" << endl;
}
}
private:
RefPtr<T> *rp; //辅助类对象指针
};
标签:应对 net 模板类 type article lse 析构函数 ons 指针
原文地址:https://www.cnblogs.com/kinglxg/p/13149531.html