溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

auto_ptr的兩種方案

發(fā)布時(shí)間:2020-07-28 07:32:34 來源:網(wǎng)絡(luò) 閱讀:331 作者:Sekai_Z 欄目:編程語言

方案一:auto_ptr的兩種方案

    因?yàn)樵陬愔袑?duì)同一塊空間的析構(gòu)在一次以上,就會(huì)發(fā)生錯(cuò)誤,所以在進(jìn)行賦值和拷貝構(gòu)造時(shí)(同一塊空間有一個(gè)以上的指針指向),保證只有一個(gè)指針指向這塊空間,對(duì)原指針賦空操作,這樣在析構(gòu)時(shí)一塊空間只會(huì)被析構(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)//自賦值檢測(cè)
		{
			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;
}

方案二:auto_ptr的兩種方案

     在原有的私有成員上添加一個(gè)bool類型的_owner成員,當(dāng)這塊空間有一個(gè)autoptr指向時(shí),這個(gè)autoptr的_owner=TRUE,當(dāng)出現(xiàn)一塊空間有多個(gè)指針指向操作時(shí),僅最新的對(duì)象的_owner成員為TRUE,其他均為FALSE.在析構(gòu)時(shí),只要找到_owner=TRUE的才進(jìn)行析構(gòu),其他則不析構(gòu),這樣保證了一塊空間不會(huì)被析構(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)//自賦值檢測(cè)
		{
			_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的兩種方案比較:

    在谷歌的說明中auto_ptr被禁止使用,如果一定要說那種方案好那我會(huì)選第一種,方案一是在方案二上的改進(jìn),由于方案二中的當(dāng)_owner=true釋放空間時(shí),_owner=false的對(duì)象中指針則成為了野指針(釋放完內(nèi)存后未把內(nèi)存置空)

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI