女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁(yè) > > 充電吧
[導(dǎo)讀]看的越多,好像關(guān)于迭代器也就越難寫了,呵呵不過(guò),還是做個(gè)記錄,聊以自慰吧1、首先迭代器是一種廣義的指針,一個(gè)數(shù)組也同樣可以作為一種迭代器的具象,迭代器提供對(duì)一個(gè)容器中的對(duì)象的訪問(wèn)方法,并且定義了容器中

看的越多,好像關(guān)于迭代器也就越難寫了,呵呵不過(guò),還是做個(gè)記錄,聊以自慰吧

1、首先迭代器是一種廣義的指針,一個(gè)數(shù)組也同樣可以作為一種迭代器的具象,迭代器提供對(duì)一個(gè)容器中的對(duì)象的訪問(wèn)方法,并且定義了容器中對(duì)象的范圍。迭代器就如同一個(gè)指針。事實(shí)上,C++的指針也是一種迭代器。但是,迭代器不僅僅是指針,因此你不能認(rèn)為他們一定具有地址值。例如,一個(gè)數(shù)組索引,也可以認(rèn)為是一種迭代器。

2、迭代器在STL中共有幾種類型:

·??????? Input iterators 提供對(duì)數(shù)據(jù)的只讀訪問(wèn)。
·??????? Output iterators 提供對(duì)數(shù)據(jù)的只寫訪問(wèn)
·??????? Forward iterators 提供讀寫操作,并能向前推進(jìn)迭代器。只能進(jìn)行++操作
·??????? Bidirectional iterators提供讀寫操作,并能向前和向后操作。基類是Bidirectional iterators可以進(jìn)行++? --操作
·??????? Random access iterators提供讀寫操作,并能在數(shù)據(jù)中隨機(jī)移動(dòng)?;愂荁idirectional iterators,可以進(jìn)行+=? -=操作

這是五種迭代器類型,但是我們知道vector? dequeue?? list map等等,的泛型迭代器,會(huì)有不同的實(shí)現(xiàn),也即上述迭代器種類只是概念性質(zhì)的分類,比如vector的iterator的實(shí)現(xiàn)其就在vector.h文件當(dāng)中而不是iterator.h文件當(dāng)中,該文件的作用,筆者尚未弄清,限于能力請(qǐng)見(jiàn)諒!??!

在vector的iterator類型即為Random access iterators類型,隨機(jī)訪問(wèn)的迭代器

在iterator模板類中,定義了5個(gè)成員類別:value_type,difference_type pointer,reference, iterator_category,用作所有其它迭代器的基類。


??? back_insert_iterator模板類,是一種輸出迭代器,用于在容器對(duì)象的尾部追加新的元素。該迭代器被賦值時(shí),調(diào)用了容器對(duì)象的push_back()成員函數(shù)。該迭代器的自增操作實(shí)際上為空操作。
??? back_inserter模板函數(shù),用于方便地由一個(gè)容器構(gòu)造出back_insert_iterator
?


? front_insert_iterator模板類,是一種輸出迭代器,用于在容器對(duì)象的頭部插入新的元素。該迭代器被賦值時(shí),調(diào)用了容器對(duì)象的push_front()成員函數(shù)。該迭代器的自增操作實(shí)際上為空操作。
??? front_inserter模板函數(shù),用于方便地由一個(gè)容器構(gòu)造出front_insert_iterator
??? insert_iterator模板類,是一種輸出迭代器,用于在容器對(duì)象的指定位置插入新的元素。該迭代器被賦值時(shí),調(diào)用了容器對(duì)象的insert()成員函數(shù)。該迭代器的自增操作實(shí)際上為空操作。
??? insert_inserter模板函數(shù),用于方便地由一個(gè)容器構(gòu)造出insert_iterator

?

在STL定義的容器中,string,vector與deque提供了隨機(jī)訪問(wèn)迭代器,list、set、multiset、map、multimap提供了雙向迭代器。

迭代器根據(jù)的是23種設(shè)計(jì)模式中的迭代器模式,該模式的主要特點(diǎn)就是隱藏內(nèi)部細(xì)節(jié),繼而可以遍歷整個(gè)中心數(shù)據(jù),而Iterator就是根據(jù)傳入數(shù)據(jù)進(jìn)行遍歷的!?。。〉髦饕袃蓚€(gè),一者迭代器,也即遍歷所有內(nèi)容的廣義迭代器,二者容器,容器是廣義的數(shù)組,我們需要得到這個(gè)容器的內(nèi)容的指針,然后會(huì)在迭代器中記錄當(dāng)前指針記錄讀取容器中的位置,需要記錄兩個(gè),一個(gè)是容器的實(shí)力對(duì)象,二者記錄容器元素的指針,進(jìn)行移動(dòng)

進(jìn)行遍歷。其C++代碼實(shí)現(xiàn)迭代器如下:


#includeusing?namespace?std;
templateclass?Iterator_m
{
public:
	virtual?T*?First()?=?0;
	virtual?T*?Next()?=?0;
	virtual?bool?isDone()?=?0;
};

templateclass?TList
{
private:
	T*?m_list;
	int?max_num;
	int?m_cur_num;
public:
	T*?getFirst()
	{
		return?m_list;
	}
	int?getNum()
	{
		return?m_cur_num;
	}
	void?Append(T?m)
	{
		if?(m_cur_num?==?max_num)
		{
			//當(dāng)前空間已經(jīng)使用完了,開(kāi)辟新的空間,首先進(jìn)行
			T*?new_list?=?new?T[max_num?*?2];
			for?(int?i?=?0;?i?<?max_num;?i++)
			{
				new_list[i]?=?m_list[i];
				delete?m_list;
				m_list?=?new_list;
			}
			max_num?*=?2;
		}
		m_list[m_cur_num]?=?m;
		m_cur_num++;
	}
	TList()
	{
		m_cur_num?=?0;
		max_num?=?24;
		m_list?=?new?T[max_num];
	}
	Iterator_m*?createIterator()
	{
		return?	new?ConcerteIterator(this);
	}
};
templateclass?ConcerteIterator?:public?Iterator_m{
private:
	TList*?m_hinstance;
	T*?m_element;
	int?m_cur_pos;
public:
	ConcerteIterator(TList*m)
	{
		m_hinstance?=?m;
		m_cur_pos?=?0;
		m_element?=?m->getFirst();
	}
	T*?Next()
	{
		return??&(m_element[m_cur_pos++]);
	}
	T*?First()
	{
		m_element?=?m_hinstance->getFirst();
		m_cur_pos?=?0;
		return?m_element;
	}
	bool?isDone()
	{
		//首先獲得m_hinstance的總的數(shù)目和m_cur_pos比較
		if?(m_cur_pos?+1==?m_hinstance->getNum())
		{
			return?true;
		}
		return?false;
	}
};

int?main()
{
	TListdsa;
	for?(int?i?=?0;?i?<?20;?i++)
	{
		dsa.Append(i);
	}
	//開(kāi)始使用迭代器進(jìn)行遍歷
	Iterator_m*?mm?=?dsa.createIterator();
	//mm->First();
	while?(!(mm->isDone()))
	{
		cout?<<?*(mm->Next())?<<?endl;
	}
	return?0;
}


綜上,其實(shí)迭代器就是一種封裝的指針,其主要作用就是記錄兩個(gè)值,其一是容器實(shí)例的指針,其二記錄當(dāng)前迭代的位置,需要自定義實(shí)現(xiàn)isDone判斷是否已經(jīng)迭代到容器的末尾?。。?!


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉