网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

auto_ptr的两种方案

方案一:

成都创新互联服务项目包括西藏网站建设、西藏网站制作、西藏网页制作以及西藏网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,西藏网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到西藏省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

    因为在类中对同一块空间的析构在一次以上,就会发生错误,所以在进行赋值和拷贝构造时(同一块空间有一个以上的指针指向),保证只有一个指针指向这块空间,对原指针赋空操作,这样在析构时一块空间只会被析构一次

class AutoPtr
{
public:
	//构造函数
	AutoPtr(T *ptr)
	:_ptr(ptr)
	{}
	//拷贝构造函数
	//管理权的转移
	AutoPtr(AutoPtr& ap)
		:_ptr(ap._ptr)
	{
		ap._ptr = NULL;
	}
	//赋值语句
	AutoPtr& operator=(AutoPtr&ap)
	{
		if (&ap != this)//自赋值检测
		{
			delete _ptr;
			_ptr = ap._ptr;
			ap._ptr = NULL;
		}
		return *this;
	}
	//重载*
	 T&operator*()
	{
		 return *_ptr;
	}
	 //重载->
	 T*operator->()
	 {
		 return _ptr;
	 }
	 //析构函数
	~AutoPtr()
	{
		if (_ptr != NULL)
			delete _ptr;
	}
private:
	T* _ptr;
};
struct A
{
	int _a;
};
int main()
{
	AutoPtrap1(new int(1));//构造函数
	AutoPtrap2(ap1);//拷贝构造函数

	AutoPtrap3(new int(2));
	ap3 = ap2;//重载=
	*ap3 = 10;//重载*

	AutoPtrap4(new A);
	ap4->_a = 20;//重载->
	return 0;
}

方案二:

     在原有的私有成员上添加一个bool类型的_owner成员,当这块空间有一个autoptr指向时,这个autoptr的_owner=TRUE,当出现一块空间有多个指针指向操作时,仅最新的对象的_owner成员为TRUE,其他均为FALSE.在析构时,只要找到_owner=TRUE的才进行析构,其他则不析构,这样保证了一块空间不会被析构多次。

template
class AutoPtr
{
public:
	//构造函数
	AutoPtr(T *ptr)
	:_ptr(ptr)
	, _owner(true)
	{}
	//拷贝构造函数
	AutoPtr(AutoPtr& ap)
		:_ptr(ap._ptr)
	{
		ap._owner = false;
		_owner = true;
	}
	//赋值语句
	AutoPtr& operator=(AutoPtr&ap)
	{
		if (&ap != this)//自赋值检测
		{
			_owner = true;
			ap._owner = false;
			_ptr = ap._ptr;
		}
		return *this;
	}
	//重载*
	 T&operator*()
	{
		 return *_ptr;
	}
	 //重载->
	 T*operator->()
	 {
		 return _ptr;
	 }
	 //析构函数
	~AutoPtr()
	{
		if (_owner == true)
			delete _ptr;
	}
private:
	T* _ptr;
	bool _owner;
};
struct A
{
	int _a;
};
int main()
{
	AutoPtrap1(new int(1));//构造函数
	AutoPtrap2(ap1);//拷贝构造函数

	AutoPtrap3(new int(2));
	ap3 = ap2;//重载=
	*ap3 = 10;//重载*

	AutoPtrap4(new A);
	ap4->_a = 20;//重载->
	return 0;
}

比较:

    在谷歌的说明中auto_ptr被禁止使用,如果一定要说那种方案好那我会选第一种,方案一是在方案二上的改进,由于方案二中的当_owner=true释放空间时,_owner=false的对象中指针则成为了野指针(释放完内存后未把内存置空)


文章题目:auto_ptr的两种方案
分享地址:
http://bjjierui.cn/article/ipodeg.html

其他资讯