您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Qt容器類怎么使用”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Qt容器類怎么使用”吧!
QList類、QLinkedList類和QVector類常常使用到的Qt容器類有QList、QLinkedList和QVector等。在開發(fā)一個(gè)較高性能需求的應(yīng)用程序時(shí)。程序猿會(huì)比較關(guān)注這些容器類的執(zhí)行效率。下表列出了QList、QLinkedList和QVector容器的時(shí)間復(fù)雜度。
當(dāng)中: “Amort.O(1)”表示僅完畢一次操作.可能會(huì)有O(n)行為.
QList<T>是眼下為止最經(jīng)常使用的容器類。它存儲(chǔ)給定數(shù)據(jù)類型T的一列數(shù)值。繼承自QList類的子類QItemSelection、QQueue、QSignalSpy以及QStringList和QTestEventList。 QList提供了能夠在列表進(jìn)行追加的QList::append()和Qlist::prepend()函數(shù)。也提供了在列表中間完畢插入操作的函數(shù)QList::insert()。相對(duì)于不論什么其它的Qt容器類。為了使可運(yùn)行代碼盡可能少。QList被高度優(yōu)化。 QList<T>維護(hù)了一個(gè)指針數(shù)組,該數(shù)組存儲(chǔ)的指針指向QList<T>存儲(chǔ)的列表項(xiàng)的內(nèi)容。
#include <QDebug> #include <QList> int main() { QList<QString> list; { QString str("This is a test string"); list<<str; } qDebug()<<list[0]<<" good evening"; return 0; }
QList<QString> list: 聲明一個(gè)QList<QString>棧對(duì)象.
list<<str; 通過(guò)操作運(yùn)算符”<<“將QString 字符串存儲(chǔ)在列表中.
QLinkedList<T>是一個(gè)鏈?zhǔn)搅斜?,它以非連續(xù)的內(nèi)存塊保存數(shù)據(jù)。
QLinkedList<T>不可以使用下標(biāo)。僅僅可以使用迭代器訪問(wèn)它的數(shù)據(jù)項(xiàng)。與QList相比,當(dāng)對(duì)一個(gè)非常大的列表進(jìn)行插入操作時(shí)。QLinkedList具有更高的效率。
QVector<T>在相鄰的內(nèi)存中存儲(chǔ)給定數(shù)據(jù)類型T的一組數(shù)值。
在一個(gè)QVector的前部或者中間位置進(jìn)行插入操作的速度是非常慢的,這是由QVector存儲(chǔ)數(shù)據(jù)的方式?jīng)Q定的。
STL風(fēng)格迭代容器類遍歷容器
對(duì)于每個(gè)容器類,Qt都提供了兩種類型的STL風(fēng)格迭代器數(shù)據(jù)類型:一種提供僅僅讀訪問(wèn),一種提供讀寫訪問(wèn)。因?yàn)閮H僅讀類型的迭代器要比讀寫迭代器速度更快,所以應(yīng)盡可能地使用僅僅讀類型的迭代器。兩種風(fēng)格迭代器分類如表表示。
<pre name="code" class="cpp">int main() { QList<int> list; for(int j=0;j<10;j++) list.insert(list.end(),j); QList<int>::iterator i;// 初始化一個(gè)讀寫迭代器,次為指針類型 for(i=list.begin();i!=list.end();++i) { qDebug()<<(*i); *i = (*i)*10; } QList<int>::const_iterator ci;// 初始化一個(gè)僅僅讀迭代器 for(ci = list.constBegin();ci != list.constEnd();++ci) qDebug()<<*ci; return 0; }
QMap類和QHash類具有很類似的功能。它們的區(qū)別僅在于: QHash具有比QMap更快的查找速度。 QHash以隨意的順序存儲(chǔ)數(shù)據(jù)項(xiàng)。而QMap總是依照鍵Key順序存儲(chǔ)數(shù)據(jù)。
QHash的鍵類型Key必須提供operator==()和一個(gè)全局的qHash(Key)函數(shù),而QMap的鍵類型Key必須提供operator<()函數(shù)。
QMap<Key,T>提供了一個(gè)從類型為Key的鍵到類型為T的值的映射。 QMap存儲(chǔ)的數(shù)據(jù)形式是一個(gè)鍵相應(yīng)一個(gè)值,而且依照鍵Key的次序存儲(chǔ)數(shù)據(jù)。為了可以支持一鍵多值的情況,QMap提供了QMap<Key,T>::insertMulti()和QMap<Key,T>::values()函數(shù)。存儲(chǔ)一鍵多值的數(shù)據(jù)時(shí),也可以使用QMultiMap<Key,T>容器,它繼承自QMap。
QHash<Key,T>具有和QMap差點(diǎn)兒全然同樣的API。
QHash維護(hù)著一張哈希表(hash table)。哈希表的大 小和QHash的數(shù)據(jù)項(xiàng)的數(shù)目相適應(yīng)。
對(duì)于每個(gè)容器類。Qt都提供了兩種類型的STL風(fēng)格迭代器數(shù)據(jù)類型:一種提供僅僅讀訪問(wèn)。一種提供讀寫訪問(wèn).
int main() { QMap<QString,QString> map; map.insert("bj","1111"); map.insert("qhd","222"); map.insert("tj","3333"); QMap<QString,QString>::Iterator mi;// 讀寫迭代器 mi = map.find("bj"); if(mi != map.end()) mi.value() = "010"; QMap<QString,QString>::const_iterator modi;// 僅僅讀迭代器 qDebug()<<" "; for(modi=map.constBegin();modi != map.constEnd(); ++modi) qDebug()<<" "<<modi.key()<<" "<<modi.value(); return 0; }
QVariant類類似于C++的聯(lián)合(union)數(shù)據(jù)類型。它可以保存非常多Qt類型的值。包含QColor、QBrush、QFont、QPen、QRect、QString、QSize等。也可以存放Qt的容器類型的值。
Qt的非常多功能都是建立在QVariant基礎(chǔ)上的,比方Qt的對(duì)象屬性以及數(shù)據(jù)庫(kù)功能等。
#include <QDebug> #include <QVariant> #include <QColor> int main() { QVariant v(709);// 聲明一個(gè)QVariant變量v,初始化為整數(shù). qDebug()<<v.toInt(); /// 轉(zhuǎn)換為整數(shù),輸出 //v.QVariant("How are you!"); // 這樣的寫法編譯不通過(guò). v = QVariant("How are you!");// 改變v的值為字符串 qDebug()<<v.toString(); QMap<QString,QVariant> map; //聲明QMap變量map map["int"] = 709; map["double"] = 709.709; map["string"] = "How are you!"; map["color"] = QColor(255,0,0); qDebug()<<map["int"]<<map["int"].toInt(); qDebug()<<map["double"]<<map["double"].toDouble(); qDebug()<<map["string"]<<map["string"].toString(); qDebug()<<map["color"]<<map["color"].value<QColor>(); QStringList s1; // 創(chuàng)建字符串列表 s1<<"A"<<"B"<<"c"<<"D"; QVariant slv(s1); // 將列表保存在QVariant變量中 if(slv.type() == QVariant::StringList ) { QStringList list=slv.toStringList(); for(int i=0;i<list.size();++i) qDebug()<<list.at(i); } return 0; }
1. Qt的<QtAlgorithms>和<QtGlobal>模塊提供了一些算法和函數(shù)。
int main() { double a = -19.3,b=9.7; double c=qAbs(a); // 返回絕對(duì)值 double max=qMax(b,c); // 返回最大值 int bn = qRound(b); // 四舍五入返回一個(gè)整數(shù) int cn = qRound(c); // qDebug()<<"a="<<a; qDebug()<<"b="<<b; qDebug()<<"c=qAbs(a)="<<c; qDebug()<<"qMax(b,c)="<<max; qDebug()<<"bn=qRound(b)="<<bn; qDebug()<<"cn=qRound(c)="<<cn; qSwap(bn,cn); // 交換兩個(gè)數(shù)的值 qDebug()<<"qSwap(bn,cn):"<<"bn="<<bn<<"cn="<<cn; return 0; }
輸出:
a= -19.3
b= 9.7
c=qAbs(a)= 19.3
qMax(b,c)= 19.3
bn=qRound(b)= 10
cn=qRound(c)= 19
qSwap(bn,cn): bn= 19 cn= 10
2. 基本正則表達(dá)式
正則表達(dá)式由表達(dá)式(expressions)、量詞(quantifiers)和斷言(assertions)組成。
(1) 最簡(jiǎn)單的表達(dá)式是一個(gè)字符。要表示字符集的表達(dá)式能夠使用類似如“[AEIOU]”表示匹配全部的大寫元音字母;使用“[^AEIOU]”則表示匹配全部非元音字母,即輔音字母;連續(xù)的字符集使用能夠使用表達(dá)式如“[a-z]”,表示匹配全部小寫英文字母。
(2) 量詞說(shuō)明表達(dá)式出現(xiàn)的次數(shù),比如“x[1,2]”表示“x”能夠至少有一個(gè)。至多兩個(gè)。 在計(jì)算機(jī)語(yǔ)言中。標(biāo)識(shí)符通常要求以字母或下畫線開頭,后面能夠是字母、數(shù)字和下畫線。滿足條件的標(biāo)識(shí)符表示為: ” [A-Za-z_]+[A-Za-z_0-9]* “
⑶“^”、“$”、“\b”都是正則表達(dá)式的斷言
到此,相信大家對(duì)“Qt容器類怎么使用”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。