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

Qt學(xué)習(xí)之容器類的使用教程詳解

 更新時(shí)間:2022年12月06日 15:47:44   作者:音視頻開發(fā)老舅  
Qt提供了多個(gè)基于模板的容器類,這些類可以用于存儲指定類型的數(shù)據(jù)項(xiàng)。本文主要介紹了Qt常用容器類的使用,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Qt提供來一組通用的基于模板的容器類.

一. QList類,QLinkedList類 和 QVector類

QList類、QLinkedList類和QVector類常常使用到的Qt容器類有QList、QLinkedList和QVector等。在開發(fā)一個(gè)較高性能需求的應(yīng)用程序時(shí)。程序猿會比較關(guān)注這些容器類的執(zhí)行效率。下表列出了QList、QLinkedList和QVector容器的時(shí)間復(fù)雜度。

當(dāng)中: “Amort.O(1)”表示僅完畢一次操作.可能會有O(n)行為.

(1)QList類

QList<T>是眼下為止最經(jīng)常使用的容器類。它存儲給定數(shù)據(jù)類型T的一列數(shù)值。繼承自QList類的子類QItemSelection、QQueue、QSignalSpy以及QStringList和QTestEventList。 QList提供了能夠在列表進(jìn)行追加的QList::append()和Qlist::prepend()函數(shù)。也提供了在列表中間完畢插入操作的函數(shù)QList::insert()。相對于不論什么其它的Qt容器類。為了使可運(yùn)行代碼盡可能少。QList被高度優(yōu)化。 QList<T>維護(hù)了一個(gè)指針數(shù)組,該數(shù)組存儲的指針指向QList<T>存儲的列表項(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>棧對象.

list<<str; 通過操作運(yùn)算符”<<“將QString 字符串存儲在列表中.

(2) QLinkedList 類

QLinkedList<T>是一個(gè)鏈?zhǔn)搅斜恚苑沁B續(xù)的內(nèi)存塊保存數(shù)據(jù)。

QLinkedList<T>不可以使用下標(biāo)。僅僅可以使用迭代器訪問它的數(shù)據(jù)項(xiàng)。與QList相比,當(dāng)對一個(gè)非常大的列表進(jìn)行插入操作時(shí)。QLinkedList具有更高的效率。

(3) QVector 類

QVector<T>在相鄰的內(nèi)存中存儲給定數(shù)據(jù)類型T的一組數(shù)值。

在一個(gè)QVector的前部或者中間位置進(jìn)行插入操作的速度是非常慢的,這是由QVector存儲數(shù)據(jù)的方式?jīng)Q定的。

STL風(fēng)格迭代容器類遍歷容器

對于每個(gè)容器類,Qt都提供了兩種類型的STL風(fēng)格迭代器數(shù)據(jù)類型:一種提供僅僅讀訪問,一種提供讀寫訪問。因?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類

QMap類和QHash類具有很類似的功能。它們的區(qū)別僅在于: QHash具有比QMap更快的查找速度。 QHash以隨意的順序存儲數(shù)據(jù)項(xiàng)。而QMap總是依照鍵Key順序存儲數(shù)據(jù)。

QHash的鍵類型Key必須提供operator==()和一個(gè)全局的qHash(Key)函數(shù),而QMap的鍵類型Key必須提供operator<()函數(shù)。

1 . QMap類

QMap<Key,T>提供了一個(gè)從類型為Key的鍵到類型為T的值的映射。 QMap存儲的數(shù)據(jù)形式是一個(gè)鍵相應(yīng)一個(gè)值,而且依照鍵Key的次序存儲數(shù)據(jù)。為了可以支持一鍵多值的情況,QMap提供了QMap<Key,T>::insertMulti()和QMap<Key,T>::values()函數(shù)。存儲一鍵多值的數(shù)據(jù)時(shí),也可以使用QMultiMap<Key,T>容器,它繼承自QMap。

2.QHash類

QHash<Key,T>具有和QMap差點(diǎn)兒全然同樣的API。

QHash維護(hù)著一張哈希表(hash table)。哈希表的大 小和QHash的數(shù)據(jù)項(xiàng)的數(shù)目相適應(yīng)。

3. STL風(fēng)格的迭代器容器遍歷

對于每個(gè)容器類。Qt都提供了兩種類型的STL風(fēng)格迭代器數(shù)據(jù)類型:一種提供僅僅讀訪問。一種提供讀寫訪問.

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類

QVariant類類似于C++的聯(lián)合(union)數(shù)據(jù)類型。它可以保存非常多Qt類型的值。包含QColor、QBrush、QFont、QPen、QRect、QString、QSize等。也可以存放Qt的容器類型的值。

Qt的非常多功能都是建立在QVariant基礎(chǔ)上的,比方Qt的對象屬性以及數(shù)據(jù)庫功能等。

#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!");  // 這樣的寫法編譯不通過.
    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;
}

四. Qt的算法

1. Qt的<QtAlgorithms>和<QtGlobal>模塊提供了一些算法和函數(shù)。

int main()
{
    double a = -19.3,b=9.7;
    double c=qAbs(a);   // 返回絕對值
    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) 最簡單的表達(dá)式是一個(gè)字符。要表示字符集的表達(dá)式能夠使用類似如“[AEIOU]”表示匹配全部的大寫元音字母;使用“[^AEIOU]”則表示匹配全部非元音字母,即輔音字母;連續(xù)的字符集使用能夠使用表達(dá)式如“[a-z]”,表示匹配全部小寫英文字母。

(2) 量詞說明表達(dá)式出現(xiàn)的次數(shù),比如“x[1,2]”表示“x”能夠至少有一個(gè)。至多兩個(gè)。 在計(jì)算機(jī)語言中。標(biāo)識符通常要求以字母或下畫線開頭,后面能夠是字母、數(shù)字和下畫線。滿足條件的標(biāo)識符表示為: ” [A-Za-z_]+[A-Za-z_0-9]* “

⑶“^”、“$”、“\b”都是正則表達(dá)式的斷言

以上就是Qt學(xué)習(xí)之容器類的使用教程詳解的詳細(xì)內(nèi)容,更多關(guān)于Qt容器類的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C語言約瑟夫環(huán)的實(shí)現(xiàn)

    C語言約瑟夫環(huán)的實(shí)現(xiàn)

    這篇文章主要介紹了C語言約瑟夫環(huán)的實(shí)現(xiàn)的相關(guān)資料,這里主要是利用數(shù)據(jù)數(shù)據(jù)結(jié)果中循環(huán)鏈表來實(shí)現(xiàn),需要的朋友可以參考下
    2017-08-08
  • C++ HLSL實(shí)現(xiàn)簡單的圖像處理功能

    C++ HLSL實(shí)現(xiàn)簡單的圖像處理功能

    本文主要介紹了HLSL實(shí)現(xiàn)簡單的圖像處理功能的方法,具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • c++中冒號(:)和雙冒號(::)的使用說明

    c++中冒號(:)和雙冒號(::)的使用說明

    以下是對c++中冒號和雙冒號的用法進(jìn)行了介紹,需要的朋友可以過來參考下
    2013-07-07
  • 利用C語言實(shí)現(xiàn)順序表的實(shí)例操作

    利用C語言實(shí)現(xiàn)順序表的實(shí)例操作

    順序表是線性表中的一種重要的數(shù)據(jù)結(jié)構(gòu),也是最基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),所以他不僅是學(xué)習(xí)中的重點(diǎn),也是應(yīng)用開發(fā)非常常用的一種數(shù)據(jù)結(jié)構(gòu)。這篇文章介紹如何利用C語言實(shí)現(xiàn)順序表。
    2016-08-08
  • C++通過文件指針獲取文件大小的方法實(shí)現(xiàn)

    C++通過文件指針獲取文件大小的方法實(shí)現(xiàn)

    本文主要介紹了C++通過文件指針獲取文件大小的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C++如何在一個(gè)函數(shù)內(nèi)返回不同類型(三種方法)

    C++如何在一個(gè)函數(shù)內(nèi)返回不同類型(三種方法)

    C++?中要在一個(gè)函數(shù)內(nèi)返回不同類型的值,你可以使用?C++17?引入的?std::variant?或?std::any,或者使用模板和多態(tài),下面將分別介紹這些方法,需要的朋友可以參考下
    2023-12-12
  • 自己簡單封裝的一個(gè)CDialog類實(shí)例

    自己簡單封裝的一個(gè)CDialog類實(shí)例

    這篇文章主要介紹了自己簡單封裝的一個(gè)CDialog類,實(shí)例分析了自定義封裝CDialog類的相關(guān)技巧,比較簡單易懂,需要的朋友可以參考下
    2015-04-04
  • C語言實(shí)現(xiàn)小小圣誕樹源代碼

    C語言實(shí)現(xiàn)小小圣誕樹源代碼

    圣誕節(jié)當(dāng)然要有個(gè)圣誕樹了,今天給你們用C語言編寫一個(gè)雪夜圣誕樹,這篇文章主要給大家介紹了關(guān)于C語言實(shí)現(xiàn)小小圣誕樹的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • C++11, 14, 17對tuple元素的訪問詳情

    C++11, 14, 17對tuple元素的訪問詳情

    這篇文章主要介紹了C++11, 14, 17對tuple元素的訪問詳情,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 詳解C語言內(nèi)核中的鏈表與結(jié)構(gòu)體

    詳解C語言內(nèi)核中的鏈表與結(jié)構(gòu)體

    Windows內(nèi)核中是無法使用vector容器等數(shù)據(jù)結(jié)構(gòu)的,當(dāng)我們需要保存一個(gè)結(jié)構(gòu)體數(shù)組時(shí),就需要使用內(nèi)核中提供的專用鏈表結(jié)構(gòu)。本文分享了幾個(gè)內(nèi)核中使用鏈表存儲多個(gè)結(jié)構(gòu)體的通用案例,希望對你有所幫助
    2022-09-09

最新評論