QList
創(chuàng)新互聯(lián)2013年開創(chuàng)至今,先為祿勸等服務(wù)建站,祿勸等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為祿勸企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
1.大多數(shù)情況下可以用QList。像prepend()、append()和insert()這種操作,通常QList比QVector快的多。這是因?yàn)镼List是基于index標(biāo)簽存儲(chǔ)它的元素項(xiàng)在內(nèi)存中(雖然內(nèi)存不連續(xù),這點(diǎn)與STL的list 是一樣的),比那種依賴iterator迭代的容器類更快捷,而且你的代碼也更少。
2.當(dāng)?shù)髦赶騋List中的一個(gè)項(xiàng)目后,如果QList進(jìn)行了插入或者刪除操作,那么這個(gè)迭代器就無效了。
3.QStringList類就是繼承于QList
容器類(注意QList 其實(shí)是一個(gè)類模板,里面裝的是QString類型,然后又有一個(gè)QStringList類繼承于它)。
QList
#include
#include
#include
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QList list;//創(chuàng)建了一個(gè)QList容器,容器內(nèi)部存儲(chǔ)QString類型的數(shù)據(jù),返回一個(gè)list對(duì)象,該對(duì)象有很多操作該容器的方法。
list<<"aa"<<"bb"<<"cc";//可以采用<<的符號(hào)將數(shù)據(jù)輸入到容器內(nèi)存儲(chǔ)。
if(list[1]=="bb")
{
list[1]="ab";
}
list.replace(2,"bc");//list對(duì)象的replace方法將指定索引位置的元素值替換成指定的類型值,參數(shù)1是list索引位置,參數(shù)2是指定替換的類型值。
qDebug()<<"the list is:";
for(int i=0;i
QMap
1.它將Key類型的鍵值映射到T類型的值上,一般每個(gè)鍵關(guān)聯(lián)一個(gè)值,特殊情況出現(xiàn)于調(diào)用insertMulti函數(shù)插入多值。
2.并且它是根據(jù)鍵順序來存儲(chǔ)它的順序的。所以,QMap強(qiáng)調(diào)順序,那么如果你存儲(chǔ)的數(shù)據(jù)不關(guān)心存儲(chǔ)順序,可以考慮使用QHash來代替它。
QMap
#include
#include
#include
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QMap map;//創(chuàng)建了一個(gè)QMap容器,容器內(nèi)存儲(chǔ)的鍵是QString類型,值是int類型,一個(gè)鍵只對(duì)應(yīng)一個(gè)值,并且存儲(chǔ)是講究鍵順序的。
map["one"]=1;//當(dāng)給一個(gè)容器內(nèi)不存在的鍵賦值時(shí),會(huì)自動(dòng)將鍵和值添加進(jìn)容器內(nèi)
map["three"]=3;
map.insert("seven",7);//也可以使用insert來為容器添加鍵值對(duì)。
int value1=map["six"];//當(dāng)采用鍵索引的方式訪問鍵的值時(shí),若容器內(nèi)無該鍵,那么就會(huì)自動(dòng)插入該新鍵,并且值默認(rèn)設(shè)為0。
qDebug()<<"value1:"< values=map.values("two");
qDebug()<<"two:"< map1,map2,map3;
map1.insert("values",1);//插入values鍵,指定第一個(gè)值為1
map1.insert("values",2);//再次為values鍵插入第二個(gè)值為2
map1.insert("qwe",888);//后面插入操作以此類推
map1.insert("qwe",999);
map2.insert("values",3);
map2.insert("rty",444);
map3=map1+map2;//相當(dāng)于把map1對(duì)象內(nèi)存儲(chǔ)的values和qwe鍵(不管鍵對(duì)應(yīng)多值還是單值),還有map2對(duì)象存儲(chǔ)的values和rty鍵相合并然后全部放入到map3容器中。
QList myValues=map3.values("values");//QMultiMap容器類對(duì)象也跟QMap一樣擁有values函數(shù)來返回指定鍵的所有值的列表
qDebug()<<"the values are:";
for(int i=0;i
Qt容器類提供了兩種風(fēng)格的迭代器,分別是JAVA風(fēng)格迭代器和STL風(fēng)格迭代器。JAVA風(fēng)格迭代器有兩種數(shù)據(jù)類型,分別是只讀迭代器和讀/寫迭代器。下面分別講解QList和QMap兩種容器類型的兩種迭代器。
例如:
QList(容器類)->QListIterator(只讀迭代器)->QMutableListIterator(讀/寫迭代器)
QListIterator(注意,JAVA風(fēng)格迭代器一直指向項(xiàng)目之間,不是直接指向項(xiàng)目)常用API:
上面的API,QMutableListIterator迭代器也都有,但由于QListIterator是只讀迭代器,所以沒有提供插入和刪除項(xiàng)目的函數(shù),而QMutableListIterator容器提供了insert和setValue函數(shù)來插入、設(shè)置值,remove函數(shù)來刪除項(xiàng)目。還有要注意的是QMutableListIterator容器雖然也有next和precious函數(shù),但是與QListIterator迭代器有所不同,前者的這兩個(gè)函數(shù)返回的是非const引用,說明可以作為左值進(jìn)行賦值操作,而后者的兩個(gè)函數(shù)返回的是const引用,說明不能用來賦值操作,只能用于讀取,很符合這個(gè)只讀迭代器的定義。下面給出QMutableListIterator迭代器三個(gè)操作項(xiàng)目的函數(shù)用法:
insert(value):在迭代器指向的位置插入一個(gè)項(xiàng)目。
setValue(value):這個(gè)函數(shù)是將指定項(xiàng)目的值設(shè)置成指定的值,所以必須有個(gè)前提就是前面執(zhí)行過next或者previous函數(shù),其實(shí)意思就是這個(gè)函數(shù)對(duì)上一次跳過的項(xiàng)目進(jìn)行賦值。
remove():刪除上一次跳過的項(xiàng)目。
案例代碼如下:
#include
#include
#include
#include
#include
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QList list;//創(chuàng)建了一個(gè)QList容器對(duì)象
list<<"A"<<"B"<<"C"<<"D";
QListIterator i(list);//創(chuàng)建了一個(gè)指向QList的只讀迭代器,用list對(duì)象作為參數(shù)
qDebug()<<"the forward is:";
while(i.hasNext())
qDebug()< j(list);//創(chuàng)建了一個(gè)讀/寫迭代器
j.toBack();
while(j.hasPrevious()){
QString str = j.previous();
if(str=="B") j.remove();
}
/*
要十分注意上面這個(gè)while循環(huán),其實(shí)原本是ABCD列表(假如從左到右排列),然后刪除B后,因?yàn)樽詈笥侄鄨?zhí)行了一次循環(huán)內(nèi)部代碼,所以迭代器就指向A的左側(cè)了。
*/
j.insert("Q");
j.toBack();
if(j.hasPrevious()) j.previous()="N";
j.previous();
j.setValue("M");
j.toFront();
qDebug()<<"the forward is:";
while(j.hasNext())
qDebug()<
例如:
QMap(容器類)->QMapIterator(只讀迭代器)->QMutableMapIterator(讀/寫迭代器)
與QListIterator迭代器類似,QMapIterator迭代器也提供了toFront()、toBack()、hasNext()、next()、peekNext()、hasPrevious()、previous()和peekPrevious()等函數(shù)。我們知道next()、peekNext()、previous()和peekPrevious()可以遍歷容器的內(nèi)容,但仔細(xì)想想,前面QList還好,只有一個(gè)值,容易理解直接遍歷取值就行,但是QMap可是字典,含有鍵值對(duì),那么該怎樣遍歷獲取鍵和值呢?next()、peekNext()、previous()和peekPrevious()這四個(gè)函數(shù)不再返回引用,而是直接返回項(xiàng)目對(duì)象??梢栽诜祷氐倪@個(gè)項(xiàng)目對(duì)象上分別使用key()和value()函數(shù)來獲取鍵和值,也可以使用QMapIterator對(duì)象的key()和value()函數(shù)獲取鍵和值,下面會(huì)有案例說明兩者獲取方法的不同。
代碼如下:
#include
#include
#include
#include
#include
#include
#include
#include
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QMap map;
map.insert("Paris","France");
map.insert("Guatemala City","Guatemala");
map.insert("Mexico City","Mexio");
map.insert("Moscow","Russia");
QMapIterator i(map);//創(chuàng)建了一個(gè)只讀迭代器指向QMap對(duì)象
while(i.hasNext()){
i.next();
/*
注意,調(diào)用next函數(shù)后返回的是一個(gè)項(xiàng)目對(duì)象,可以使用這個(gè)項(xiàng)目對(duì)象的key()和value()方法獲取,
例如:i.next().key()。但是對(duì)于這里的需求是我們需要獲取鍵和值,如果連續(xù)兩次執(zhí)行i.next().key()
和i.next().value()那么迭代器就移動(dòng)兩次了,很明顯不符合我們的需求。其實(shí)當(dāng)單獨(dú)執(zhí)行了這個(gè)函數(shù),迭代器也向后移
動(dòng)了一次,并且內(nèi)部已經(jīng)保存了跳過的
項(xiàng)目的鍵和值,它告訴我們可以通過i對(duì)象的key()和
value()函數(shù)獲取。就好像下面那條語句一樣。
*/
qDebug()< j(map);
while(j.hasNext()){
//下面的j.next.key()語句可以看出,就是我們上面介紹的那樣,不過這里的應(yīng)用場(chǎng)景是為了只單獨(dú)獲取鍵,然后匹配以City的項(xiàng)目后再刪除。
if(j.next().key().endsWith("City"))
j.remove();
}
while(j.hasPrevious()){
j.previous();
qDebug()<