码迷,mamicode.com
首页 > 编程语言 > 详细

C++11封装智能指针

时间:2020-06-16 23:16:35      阅读:82      评论:0      收藏:0      [点我收藏+]

标签:应对   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; //辅助类对象指针
};

C++11封装智能指针

标签:应对   net   模板类   type   article   lse   析构函数   ons   指针   

原文地址:https://www.cnblogs.com/kinglxg/p/13149531.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!