C++智能指针的设计和实现

一、智能指针

在C++语言编程时,当类中有指针成员时,一般有两种方式来管理指针成员:一是采用值型的方式管理,每个类对象都保留一份指针指向的对象的拷贝;另一种更优雅的方式是使用智能指针,从而实现指针指向的对象的共享。
智能指针(smart pointer)的一种通用实现技术是使用引用计数(reference count)。智能指针类将一个计数器与类指向的对象相关联,引用计数跟踪该类有多少个对象共享同一指针。
每次创建类的新对象时,初始化指针并将引用计数置为1;当对象作为另一对象的副本而创建时,拷贝构造函数拷贝指针并增加与之相应的引用计数;对一个对象进行赋值时,赋值操作符减少左操作数所指对象的引用计数(如果引用计数为减至0,则删 除对象),并增加右操作数所指对象的引用计数;调用 析构函数 时,析构函数减少引用计数(如果引用计数减至0,则删除基础对象)。

二、智能指针的一般实现

智能指针通常使用类模板来实现。模拟类指针的各种行为。但是,其最重要的作用是对类指针成员的管理,防止悬垂指针的出现。

template<class T>
class SmartPointer{
	public:
		SmartPointer(T *t):pt(t){}
		T& operator *(){ return *pt; }
		T* operator ->() { return pt; }
	private:
		T *pt;
};

三、引用计数的实现


为了实现引用计数,我们定义一个_counter类来记录引用次数,把_counter类的所有成员设定为private,因为其他的类型并不需要访问_counter,只有SmartPointer对其进行操作就行了,SmartPointer将设为其友元类。
class _counter{
	template<class T> friend class SmartPointer;
	_counter(int u):use(u){}
	~_counter(){}
	int use;
};
在SmartPointer类中,保留_counter的指针。
template<class T>
class SmartPointer{
	public:
		SmartPointer(T *t):pc(new _counter(1)){
			cout<<"SmartPointer::SmartPointer() invoded use is: "<<pc->use<<endl;
			this->pt = t;
		}

		SmartPointer(SmartPointer<T> &rhs){
			this->pc = rhs.pc;
			this->pt = rhs.pt;
			this->pc->use++;
			cout<<"SmartPointer copy invoked use is: "<<pc->use<<endl;
		}

		~SmartPointer(){
			pc->use--;
			cout<<"SmartPointer::~SmartPointer() invoded use is: "<<pc->use<<endl;
			if(pc->use == 0)
			{
				delete pt;
				delete pc;
			}
		}

		SmartPointer<T>& operator=(SmartPointer<T> rhs){
			if(rhs == *this){
				return *this;
			}

			this->pt = rhs.pt;
			this->pc = rhs.pc;
			this->pc->use++;
			cout<<"SmartPointer::operator=() invoked  use is: "<<pc->use<<endl;
			return *this;
		}

	private:
		T *pt;
		_counter* pc;
};

例如:我们有一个HasPtr类,其类成员中有一个为指针*p。

class HasPtr{
	public:
		HasPtr(int val):value(val),p(new int(3)){
			cout<<"HasPtr::HasPtr() invoked"<<endl;
		}
		~HasPtr(){ delete p; cout<<"HasPtr::~HasPtr() invoded"<<endl;}

	private:
		int *p;
		int value;
};

如果如下调用:
HasPtr *php = new HasPtr(3);
SmartPointer<HasPtr> psp(php);
SmartPointer<HasPtr> npsp(psp);

我们现在有两个智能指针对象,指向同一个HasPtr对象,其模型如下:

_counter的use成员(引用计数)为2.

四、测试

int main(void)
{
	HasPtr *php = new HasPtr(3);
	SmartPointer<HasPtr> psp(php);
	SmartPointer<HasPtr> npsp(psp);
	SmartPointer<HasPtr> nnpsp = npsp;


	return 0;
}
使用gcc编译器,运行结果如下:



  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
【为什么还需要学习C++?】 你是否接触很多语言,但从来没有了解过编程语言的本质?你是否想成为一名资深开发人员,想开发别人做不了的高性能程序?你是否经常想要窥探大型企业级开发工程的思路,但苦于没有基础只能望洋兴叹? 那么C++就是你个人能力提升,职业之路进阶的不二之选。【课程特色】 1.课程共19大章节,239课时内容,涵盖数据结构、函数、类、指针、标准库全部知识体系。2.带你从知识与思想的层面从0构建C++知识框架,分析大型项目实践思路,为你打下坚实的基础。3.李宁老师结合4大国外顶级C++著作的精华为大家推出的《征服C++11》课程。【学完后我将达到什么水平?】 1.对C++的各个知识能够熟练配置、开发、部署;2.吊打一切关于C++的笔试面试题;3.面向物联网的“嵌入式”和面向大型化的“分布式”开发,掌握职业钥匙,把握行业先机。【面向人群】 1.希望一站式快速入门的C++初学者; 2.希望快速学习 C++、掌握编程要义、修炼内功的开发者; 3.有志于挑战更高级的开发项目,成为资深开发的工程师。 【课程设计】 本课程包含3大模块基础篇本篇主要讲解c++的基础概念,包含数据类型、运算符等基本语法,数组、指针、字符串等基本词法,循环、函数、类等基本句法等。进阶篇本篇主要讲解编程中常用的一些技能,包含类的高级技术、类的继承、编译链接和命名空间等。提升篇:本篇可以帮助学员更加高效的进行c++开发,其中包含类型转换、文件操作、异常处理、代码重用等内容。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值