您的位置:首页 > 编程语言 > C语言/C++

【C++】智能指针简述(三):scoped_ptr

2017-04-01 22:09 218 查看
  在介绍scoped_ptr之前,我们先回顾一下前两篇文章的内容.

  首先,智能指针采用RAII机制,通过对象来管理指针,构造对象时,完成资源的初始化;析构对象时,对资源进行清理及汕尾.

  auto_ptr,通过转移管理权来完成对象的拷贝与赋值,在实际开发中并不实用.

  回顾完智能指针的背景及auto_ptr的特性之后,本文来介绍scoped_ptr的实现原理及特性.

  scoped_ptr与auto_ptr类似,但最大的区别就是它不能转让管理权.也就是说,scoped_ptr禁止用户进行拷贝与赋值.

  诶?当我了解到这里的时候,那么问题来了:scoped_ptr是通过什么方法来做到禁止用户进行拷贝与赋值呢?

  换句话说:C++中有什么方法可以禁止一个类进行拷贝构造和赋值呢?

  那么我第一时间想到的是:既然禁止你进行拷贝和赋值,那我不写相应函数不就行了?

  在C++中,如果你不定义拷贝构造函数/赋值运算符重载函数的话,当你在调用时,系统会自动默认生成相应的函数.

  但,系统默认生成的函数,完成的仅仅是值的拷贝,即浅拷贝!(当然,深浅拷贝的问题,就不在这里多说了,以后再谈.)

  也就是说,这种方法绝对没办法禁止一个类进行拷贝构造与赋值.

  此时,我突然灵光一现:想起了《Effective C++》中某条款提到了这个,其实要做的很简单:

  我们只需把拷贝构造函数与赋值运算符重载的访问限定符设置为private,并且只给出其声明,就像这样:

class ScopedPtr{
private:
ScopedPtr(const ScopedPtr& sp);
ScopedPtr& operator(const ScopedPtr& sp);
};

  因此,scoped_ptr的"核心技术",再次被我们所剖析、掌握!

  最终,给出我写的精简版代码:

/*
*文件说明:模拟实现scoped_ptr
*作者:高小调
*日期:2017-03-31
*集成开发环境:Microsoft Visual Studio 2010
*/
#pragma once
template<typename T>
class ScopedPtr{
public:
//构造函数
ScopedPtr(T* ptr = NULL)
:_ptr(ptr){}
//析构函数
~ScopedPtr(){
if(_ptr!=NULL){
delete _ptr;
_ptr=NULL;
}
}
private:
//拷贝构造
ScopedPtr(const ScopedPtr &sp);
//赋值运算符重载
ScopedPtr& operator=(const ScopedPtr &sp);
private:
T *_ptr;
};

void TestScopedPtr(){
ScopedPtr<int> sp1(new int(10));
ScopedPtr<int> sp2(new int(20));
//ScopedPtr<int> sp3(sp1);		//错误
//sp1 = sp2						//错误
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐