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的才进行析构,其他则不析构,这样保证了一块空间不会被析构多次。
templateclass 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() { AutoPtr ap1(new int(1));//构造函数 AutoPtr ap2(ap1);//拷贝构造函数 AutoPtr ap3(new int(2)); ap3 = ap2;//重载= *ap3 = 10;//重载* AutoPtrap4(new A); ap4->_a = 20;//重载-> return 0; }
比较:
在谷歌的说明中auto_ptr被禁止使用,如果一定要说那种方案好那我会选第一种,方案一是在方案二上的改进,由于方案二中的当_owner=true释放空间时,_owner=false的对象中指针则成为了野指针(释放完内存后未把内存置空)
文章标题:auto_ptr的两种方案
文章路径:http://www.jxjierui.cn/article/ipodeg.html


咨询
建站咨询
