新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
方案一:
成都创新互联公司致力于成都网站设计、成都网站制作,成都网站设计,集团网站建设等服务标准化,推过标准化降低中小企业的建站的成本,并持续提升建站的定制化服务水平进行质量交付,让企业网站从市场竞争中脱颖而出。 选择成都创新互联公司,就选择了安全、稳定、美观的网站建设服务!因为在类中对同一块空间的析构在一次以上,就会发生错误,所以在进行赋值和拷贝构造时(同一块空间有一个以上的指针指向),保证只有一个指针指向这块空间,对原指针赋空操作,这样在析构时一块空间只会被析构一次
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() { 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; }
方案二:
在原有的私有成员上添加一个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的对象中指针则成为了野指针(释放完内存后未把内存置空)
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。