Qt?關(guān)于容器的遍歷迭代器的使用問題小結(jié)
前言:
Qt(官方發(fā)音 [kju:t],音同 cute)是一個(gè)跨平臺的 C++ 開發(fā)庫,主要用來開發(fā)圖形用戶界面(Graphical User Interface,GUI)程序,當(dāng)然也可以開發(fā)不帶界面的命令行(Command User Interface,CUI)程序。
對容器進(jìn)行遍歷通常會使用迭代器,迭代器提供了一個(gè)統(tǒng)一的方法來訪問容器中的項(xiàng)目。Qt的容器類提供了兩種類型的迭代器,一個(gè)是Java風(fēng)格迭代器,一個(gè)是STL風(fēng)格迭代器。一般C++程序員會比較習(xí)慣使用STL風(fēng)格迭代器。如果只想按順序遍歷一個(gè)容器中的項(xiàng)目的話,還可以使用Qt的foreach關(guān)鍵字。
面試時(shí),也會對迭代器的相關(guān)只是進(jìn)行提問,這里整理了STL風(fēng)格迭代器和foreach關(guān)鍵字的相關(guān)知識。
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í)會先修改迭代器,然后返回修改改后的迭代器的一個(gè)引用;當(dāng)作為后綴時(shí),在修改迭代器以前會對其進(jìn)行復(fù)制,然后返回這個(gè)復(fù)制。如果在表達(dá)式中不對返回值進(jìn)行處理,那么最好使用前綴操作符,這樣會更快一些。
- 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è)特殊簡化版,寫法類似于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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實(shí)現(xiàn)簡單停車場管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡單停車場管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
MySQL系列教程之使用C語言來連接數(shù)據(jù)庫
c語言操作Mysql數(shù)據(jù)庫,主要就是為了實(shí)現(xiàn)對數(shù)據(jù)庫的增、刪、改、查等操作,下面這篇文章主要給大家介紹了關(guān)于MySQL系列教程之使用C語言來連接數(shù)據(jù)庫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
C語言修煉之路數(shù)據(jù)類型悟正法 解析存儲定風(fēng)魔下篇
使用編程語言進(jìn)行編程時(shí),需要用到各種變量來存儲各種信息。變量保留的是它所存儲的值的內(nèi)存位置。這意味著,當(dāng)您創(chuàng)建一個(gè)變量時(shí),就會在內(nèi)存中保留一些空間。您可能需要存儲各種數(shù)據(jù)類型的信息,操作系統(tǒng)會根據(jù)變量的數(shù)據(jù)類型,來分配內(nèi)存和決定在保留內(nèi)存中存儲什么2022-02-02

