方案一:
成都創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括西藏網(wǎng)站建設(shè)、西藏網(wǎng)站制作、西藏網(wǎng)頁制作以及西藏網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,西藏網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到西藏省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
因?yàn)樵陬愔袑ν粔K空間的析構(gòu)在一次以上,就會發(fā)生錯誤,所以在進(jìn)行賦值和拷貝構(gòu)造時(同一塊空間有一個以上的指針指向),保證只有一個指針指向這塊空間,對原指針賦空操作,這樣在析構(gòu)時一塊空間只會被析構(gòu)一次
class AutoPtr { public: //構(gòu)造函數(shù) AutoPtr(T *ptr) :_ptr(ptr) {} //拷貝構(gòu)造函數(shù) //管理權(quán)的轉(zhuǎn)移 AutoPtr(AutoPtr<T>& ap) :_ptr(ap._ptr) { ap._ptr = NULL; } //賦值語句 AutoPtr<T>& operator=(AutoPtr<T>&ap) { if (&ap != this)//自賦值檢測 { delete _ptr; _ptr = ap._ptr; ap._ptr = NULL; } return *this; } //重載* T&operator*() { return *_ptr; } //重載-> T*operator->() { return _ptr; } //析構(gòu)函數(shù) ~AutoPtr() { if (_ptr != NULL) delete _ptr; } private: T* _ptr; }; struct A { int _a; }; int main() { AutoPtr<int>ap1(new int(1));//構(gòu)造函數(shù) AutoPtr<int>ap2(ap1);//拷貝構(gòu)造函數(shù) AutoPtr<int>ap3(new int(2)); ap3 = ap2;//重載= *ap3 = 10;//重載* AutoPtr<A>ap4(new A); ap4->_a = 20;//重載-> return 0; }
方案二:
在原有的私有成員上添加一個bool類型的_owner成員,當(dāng)這塊空間有一個autoptr指向時,這個autoptr的_owner=TRUE,當(dāng)出現(xiàn)一塊空間有多個指針指向操作時,僅最新的對象的_owner成員為TRUE,其他均為FALSE.在析構(gòu)時,只要找到_owner=TRUE的才進(jìn)行析構(gòu),其他則不析構(gòu),這樣保證了一塊空間不會被析構(gòu)多次。
template<class T> class AutoPtr { public: //構(gòu)造函數(shù) AutoPtr(T *ptr) :_ptr(ptr) , _owner(true) {} //拷貝構(gòu)造函數(shù) AutoPtr(AutoPtr<T>& ap) :_ptr(ap._ptr) { ap._owner = false; _owner = true; } //賦值語句 AutoPtr<T>& operator=(AutoPtr<T>&ap) { if (&ap != this)//自賦值檢測 { _owner = true; ap._owner = false; _ptr = ap._ptr; } return *this; } //重載* T&operator*() { return *_ptr; } //重載-> T*operator->() { return _ptr; } //析構(gòu)函數(shù) ~AutoPtr() { if (_owner == true) delete _ptr; } private: T* _ptr; bool _owner; }; struct A { int _a; }; int main() { AutoPtr<int>ap1(new int(1));//構(gòu)造函數(shù) AutoPtr<int>ap2(ap1);//拷貝構(gòu)造函數(shù) AutoPtr<int>ap3(new int(2)); ap3 = ap2;//重載= *ap3 = 10;//重載* AutoPtr<A>ap4(new A); ap4->_a = 20;//重載-> return 0; }
比較:
在谷歌的說明中auto_ptr被禁止使用,如果一定要說那種方案好那我會選第一種,方案一是在方案二上的改進(jìn),由于方案二中的當(dāng)_owner=true釋放空間時,_owner=false的對象中指針則成為了野指針(釋放完內(nèi)存后未把內(nèi)存置空)
文章題目:auto_ptr的兩種方案
當(dāng)前鏈接:http://aaarwkj.com/article46/ipodeg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、定制網(wǎng)站、用戶體驗(yàn)、企業(yè)建站、網(wǎng)站策劃、
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)