Qt?關(guān)于容器的遍歷迭代器的使用問題小結(jié)
前言:
Qt(官方發(fā)音 [kju:t],音同 cute)是一個(gè)跨平臺(tái)的 C++ 開發(fā)庫(kù),主要用來開發(fā)圖形用戶界面(Graphical User Interface,GUI)程序,當(dāng)然也可以開發(fā)不帶界面的命令行(Command User Interface,CUI)程序。
對(duì)容器進(jìn)行遍歷通常會(huì)使用迭代器,迭代器提供了一個(gè)統(tǒng)一的方法來訪問容器中的項(xiàng)目。Qt的容器類提供了兩種類型的迭代器,一個(gè)是Java風(fēng)格迭代器,一個(gè)是STL風(fēng)格迭代器。一般C++程序員會(huì)比較習(xí)慣使用STL風(fēng)格迭代器。如果只想按順序遍歷一個(gè)容器中的項(xiàng)目的話,還可以使用Qt的foreach關(guān)鍵字。
面試時(shí),也會(huì)對(duì)迭代器的相關(guān)只是進(jìn)行提問,這里整理了STL風(fēng)格迭代器和foreach關(guān)鍵字的相關(guān)知識(shí)。
STL風(fēng)格迭代器:
每一個(gè)容器類都有兩個(gè)STL風(fēng)格迭代器類型,一個(gè)提供只讀訪問,一個(gè)提供讀/寫訪問。只讀迭代器要比讀/寫迭代器快很多,所以盡可能使用只讀迭代器。
- 只讀迭代器:“容器類型”::const_iterator;例如:QList<QString>::const_iterator、QMap<QString, int>::const_iterator。
- 讀/寫迭代器:“容器類型”::iterator;例如:QVector<QString>::iterator、QHash<QString, int>::iterator。
使用方法:
QList<QString> list; list<<"A"<<"B"<<"C"<<"D"; //只讀迭代器 QList<QString>::iterator iter; for(iter = list.begin(); iter != list.end(); ++iter) { qDebug() <<*iter; } //讀/寫迭代器 QList<QString>::const_iterator constIter; for(constIter = list.constBegin(); constIter != list.constEnd(); ++constIter) { qDebug() << *constIter; }
其他:
- STL風(fēng)格迭代器的API模仿了數(shù)組的指針,例如,使用“++”操作符來向后移動(dòng)迭代器使其指向下一個(gè)項(xiàng)目、使用“*”操作符返回迭代器指向的項(xiàng)目等。
- STL風(fēng)格迭代器是直接指向項(xiàng)目的。begin()函數(shù)返回容器中的第一個(gè)項(xiàng)目,end()函數(shù)返回容器最后一個(gè)項(xiàng)目的下一個(gè)假想的虛項(xiàng)目,這個(gè)項(xiàng)目標(biāo)志著一個(gè)無效的位置,當(dāng)列表為空時(shí),begin()函數(shù)等價(jià)于end()函數(shù)。
- STL風(fēng)格迭代器中的“++”和“--”操作符既可以作為前綴(++iter,--iter)操作符,也可以作為后綴(i++,i--)操作符。當(dāng)作為前綴時(shí)會(huì)先修改迭代器,然后返回修改改后的迭代器的一個(gè)引用;當(dāng)作為后綴時(shí),在修改迭代器以前會(huì)對(duì)其進(jìn)行復(fù)制,然后返回這個(gè)復(fù)制。如果在表達(dá)式中不對(duì)返回值進(jìn)行處理,那么最好使用前綴操作符,這樣會(huì)更快一些。
- STL風(fēng)格迭代器常用API:
表達(dá)式 | 行為 |
---|---|
*i | 返回當(dāng)前項(xiàng)目 |
++i | 移動(dòng)迭代器到下一個(gè)項(xiàng)目 |
i += n | 使迭代器向后移動(dòng)n個(gè)項(xiàng)目 |
--i | 移動(dòng)迭代器到上一個(gè)項(xiàng)目 |
i -= n | 使迭代器向前移動(dòng)n個(gè)項(xiàng)目 |
i-j | 返回迭代器i和迭代器j之間的項(xiàng)目的數(shù)目 |
foreach關(guān)鍵字:
foreach關(guān)鍵字是Qt向C++語言中添加的一個(gè)用來進(jìn)行容器順序遍歷的關(guān)鍵字。
使用方法:
QList<QString> list; list<<"A"<<"B"<<"C"<<"D"; foreach(QString str, list) { qDebug() << str; }
其他:
- foreach其實(shí)是for循環(huán)的一個(gè)特殊簡(jiǎn)化版,寫法類似于C++11中for的新寫法,只不過foreach兩個(gè)參數(shù)中間是“,”,C++11的for是“:”。
- foreach適用于循環(huán)次數(shù)未知,或者計(jì)算循環(huán)次數(shù)比較麻煩情況下使用效率更高,但是更為復(fù)雜的一些循環(huán)還是需要用到for循環(huán)效率更高。
- 在foreach循環(huán)中也可以使用break和continue語句。
到此這篇關(guān)于Qt 關(guān)于容器的遍歷迭代器的使用問題小結(jié)的文章就介紹到這了,更多相關(guān)Qt容器的遍歷內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++11新特性中auto 和 decltype 區(qū)別和聯(lián)系
這篇文章主要介紹了C++11新特性中auto 和 decltype 區(qū)別和聯(lián)系的相關(guān)資料,需要的朋友可以參考下2017-01-01深入探究C++中的容器適配器與仿函數(shù)技術(shù)
C++中的容器適配器和仿函數(shù)是實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)與算法的重要技術(shù),容器適配器可以將一個(gè)容器轉(zhuǎn)換為另一個(gè)形式,仿函數(shù)則可以自定義數(shù)據(jù)類型的比較、排序、計(jì)算等行為,提高程序的靈活性和可重用性2023-04-04C語言實(shí)現(xiàn)學(xué)生籍貫信息記錄簿
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)學(xué)生籍貫信息記錄簿,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06C++ OpenCV實(shí)現(xiàn)抖音"藍(lán)線挑戰(zhàn)"特效
這篇文章主要介紹了如何使用OpenCV C++ 實(shí)現(xiàn)抖音上的特效“藍(lán)線挑戰(zhàn)”。文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定的幫助,需要的可以參考一下2022-01-01C++如何獲取當(dāng)前系統(tǒng)時(shí)間及格式化輸出
這篇文章主要介紹了C++如何獲取當(dāng)前系統(tǒng)時(shí)間及格式化輸出的實(shí)例代碼,主要用到time()及strftime()函數(shù),通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02