欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c++將vector迭代器轉(zhuǎn)換為指針的實(shí)現(xiàn)方式

 更新時(shí)間:2022年11月11日 16:35:10   作者:百口可樂(lè)__  
這篇文章主要介紹了c++將vector迭代器轉(zhuǎn)換為指針的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

將vector迭代器轉(zhuǎn)換為指針

定義一個(gè)Domain結(jié)構(gòu)體以及容器、迭代器

struct Domain{
	int ID;
	string name
	string description;
};
vector <struct Domain> domainVec;
int main(){
	...
	vector <struct Domain>::iterator iter=domainVec.begin();
	...
return 0;
}

若要從迭代器iter中取出特定元素,可以使用

struct Domain domain=*iter;

指針相對(duì)于變量,可以通過(guò)刪除指針,賦值NULL這種編程技巧,表示指針?biāo)赶虻淖兞坎豢捎没蛞咽А6兞烤蜎](méi)有這種特性了,變量是永遠(yuǎn)有值的。

轉(zhuǎn)化成指針,就需要使用如下形式

struct domain *pDomain=&*iter;

但是此時(shí)pDomain成為一個(gè)危險(xiǎn)的指針,可以通過(guò)pDomain++、pDomain--等形式訪問(wèn)domainVec容器中的內(nèi)容,容易出現(xiàn)越界等錯(cuò)誤。

應(yīng)該注意

cout<<"domain ID="<<p->ID<<endl;
p++;
p++;
...
cout<<"domain ID="<<p->ID<<endl;

迭代器對(duì)容器刪除等操作??赡茉斐纱酥羔樦赶虻膬?nèi)容改變!

vector與迭代器的使用

這是《C++ Primer》第五版關(guān)于vector和迭代器的讀書筆記

?。?!本文的源碼均來(lái)自于《C++ Primer》第五版?。。。赡軙?huì)稍作修改)

The source codes in this article are all from C++ Primer, The Fifth Edition

1. 標(biāo)準(zhǔn)庫(kù)vector

vector:一個(gè)支持自動(dòng)擴(kuò)容,基于數(shù)組的容器

vector的初始化:截圖來(lái)自于《C++ Primer》第五版,P87

vector的操作:截圖來(lái)自于《C++ Primer》第五版,P91

2. 迭代器

迭代器(iterator):迭代器用于迭代訪問(wèn)標(biāo)準(zhǔn)庫(kù)容器(例如vector)和string中的元素

2.1. 獲取和使用迭代器

  • begin函數(shù):基本所有標(biāo)準(zhǔn)庫(kù)容器都有這個(gè)成員函數(shù),它返回一個(gè)位于容器首個(gè)元素位置的迭代器,成為首迭代器
  • end函數(shù):基本所有標(biāo)準(zhǔn)庫(kù)容器都有這個(gè)成員函數(shù),它返回一個(gè)位于容器末尾元素后一個(gè)位置的迭代器,成為尾迭代器(也就是說(shuō),end指向的內(nèi)容不存在與容器中,它指向一個(gè)“尾后”的位置)
  • 容器為空:如果容器為空,那么首迭代器和尾迭代器都指向“尾后”
vector<int> v{1, 2, 3, 4, 5}
auto b = v.begin(), e = v.end();	// 創(chuàng)建兩個(gè)迭代器,一個(gè)首迭代器,一個(gè)尾迭代器

迭代器運(yùn)算符:截圖來(lái)自于《C++ Primer》第五版,P96

解引迭代器訪問(wèn)&更改元素:用解引用符來(lái)訪問(wèn)迭代器指向的內(nèi)容

string s1("ABC");
for (auto it = s1.begin(); it != s1.end(); it++)
{
	*it = tolower(*it);
}
cout << s1 << endl;		// 輸出“abc”

箭頭運(yùn)算符訪問(wèn)成員:通過(guò)箭頭運(yùn)算符,我們可以直接訪問(wèn)迭代器指向內(nèi)容的成員,而不用先解引再訪問(wèn)

vector<string> v1{"hello", "hi"};
auto it = v1.begin();

// 下面兩行代碼的功能是一樣的
cout << (*it).size() << endl;	// 輸出“5”
cout << it->size() << endl;		// 輸出“5”

2.2. 迭代器的類型

  • iterator類型:可以讀取并寫入元素的迭代器,類似指針一樣的存在
  • const_iterator類型:只能讀取元素,不能寫入元素的迭代器,類似指向常量的指針
  • 常量對(duì)象迭代器為const_iterator:若我們定義一個(gè)常量,并構(gòu)造它的迭代器,那么auto會(huì)判斷它為const_iteratorcbegin()和cend():與begin()和end()類似,唯一的不同點(diǎn)在于cbegin()和cend()返回的迭代器類型必為const_iterator
const vector<int> myVec;
auto it = myVec.begin();	// it的類型為const_iterator

迭代器失效:若在使用迭代器時(shí),更改了容器的元素?cái)?shù)量(加入或者刪除元素),那么迭代器會(huì)失效,因?yàn)楹苡锌赡艿髦赶虻膬?nèi)容將不復(fù)存在亦或者錯(cuò)位

2.3. 迭代器運(yùn)算

迭代器常用運(yùn)算:截圖來(lái)自于《C++ Primer》第五版,P99

迭代器和二分查找:十分出名的二分查找法可以用迭代器快速實(shí)現(xiàn),使用迭代器的好處在于不用處理元素下標(biāo),因?yàn)榻?jīng)驗(yàn)不豐富的程序員很容易在使用下標(biāo)時(shí)發(fā)生下標(biāo)超限(Index Out of Range)或者緩存溢出問(wèn)題(Buffer Overflow)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • VC打印word,excel文本文件的方法

    VC打印word,excel文本文件的方法

    這篇文章主要介紹了VC打印word,excel文本文件的方法,是VC操作文本文件中非常實(shí)用的技巧,需要的朋友可以參考下
    2014-10-10
  • C++11原子操作詳解

    C++11原子操作詳解

    這篇文章主要為大家介紹了C++的原子操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-11-11
  • C++多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換

    C++多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換

    最近在C++編程中經(jīng)常遇到需要多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換的問(wèn)題,自己寫了一個(gè)類來(lái)封裝wchar_t與char類型間的轉(zhuǎn)換
    2012-11-11
  • 歸并排序的遞歸實(shí)現(xiàn)與非遞歸實(shí)現(xiàn)代碼

    歸并排序的遞歸實(shí)現(xiàn)與非遞歸實(shí)現(xiàn)代碼

    以下是對(duì)歸并排序的遞歸實(shí)現(xiàn)與非遞歸實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-08-08
  • C++實(shí)現(xiàn)LeetCode(104.二叉樹(shù)的最大深度)

    C++實(shí)現(xiàn)LeetCode(104.二叉樹(shù)的最大深度)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(104.二叉樹(shù)的最大深度),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • VS報(bào)錯(cuò)C1189及MSB3721解決方法

    VS報(bào)錯(cuò)C1189及MSB3721解決方法

    在使用VS進(jìn)行CUDA編譯時(shí)出現(xiàn)錯(cuò)誤,本文主要介紹了VS報(bào)錯(cuò)C1189及MSB3721解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-06-06
  • STl中的排序算法詳細(xì)解析

    STl中的排序算法詳細(xì)解析

    全排序即把所給定范圍所有的元素按照大小關(guān)系順序排列。sort采用的是成熟的"快速排序算法"(目前大部分STL版本已經(jīng)不是采用簡(jiǎn)單的快速排序,而是結(jié)合內(nèi)插排序算法)
    2013-09-09
  • OpenCV 圓與矩形識(shí)別的方法

    OpenCV 圓與矩形識(shí)別的方法

    這篇文章主要介紹了OpenCV 圓與矩形識(shí)別的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • C++?opencv學(xué)習(xí)之圖像像素的邏輯操作

    C++?opencv學(xué)習(xí)之圖像像素的邏輯操作

    圖像的像素操作包括讀寫操作、算數(shù)操作、邏輯運(yùn)算操作等,下面這篇文章主要給大家介紹了關(guān)于C++?opencv學(xué)習(xí)之圖像像素的邏輯操作的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • C語(yǔ)言對(duì)磁盤文件進(jìn)行快速排序簡(jiǎn)單實(shí)例

    C語(yǔ)言對(duì)磁盤文件進(jìn)行快速排序簡(jiǎn)單實(shí)例

    這篇文章主要介紹了C語(yǔ)言對(duì)磁盤文件進(jìn)行快速排序簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-06-06

最新評(píng)論