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

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

 更新時(shí)間:2023年03月28日 16:07:21   作者:波雅_(tái)漢庫(kù)克  
Qt容器主要優(yōu)點(diǎn)就是在所有的平臺(tái)上的運(yùn)行都表現(xiàn)的一致,并且它們都是隱含共享的,這篇文章就來(lái)和大家講講Qt中容器的具體用法吧,希望對(duì)大家有所幫助

Qt容器

Qt容器主要優(yōu)點(diǎn)就是在所有的平臺(tái)上的運(yùn)行都表現(xiàn)的一致,并且它們都是隱含共享的.Qt容器的另外一個(gè)主要特征就是易于使用的迭代器類,它們可以利用QDataStream變成數(shù)據(jù)流,而且他們通??梢允褂脠?zhí)行文件中的代碼量比相應(yīng)的STL類中的要少.最后Qt/Embedded Linux 支持的一些硬件平臺(tái)只能使用Qt容器.

連續(xù)容器

QVector<T>

向量與普通數(shù)組的區(qū)別在于,向量知道自己的大小,并且可以重新被定義大小,向量在末尾添加額外的項(xiàng)是非??斓?但是在向量前面或者中間插入項(xiàng)是非常耗時(shí)的.

初始化QVector

需要添加頭文件#include <QtCore/qvector.h>

    // 初始化定義向量大小
    QVector<double> qvect(3);
    qvect[0] = 0.1;
    qvect[1] = 0.2;
    qvect[2] = 0.3;
    // 初始化未定義向量
    QVector<double> qvect1;
    qvect1.append(0.001);
    qvect1.append(0.002);
    qvect1.append(0.003);

當(dāng)然,定義大小后也可以使用append函數(shù)再后面追加.

    // 初始化定義向量大小
    QVector<double> qvect2(3);
    qvect2.append(0.22);
    qvect2.append(0.21);
    qvect2.append(0.23);
    qvect2.append(0.24);

這樣追加后,向量的大小就會(huì)根據(jù)實(shí)際情況了.

QLinkedList<T>

QVector在開(kāi)頭或者中間插入項(xiàng)或者除去這些項(xiàng)都是非常費(fèi)時(shí)的,也可以使用QLinkedList,這是一種把項(xiàng)存儲(chǔ)在不相鄰的位置的數(shù)據(jù)結(jié)構(gòu).與QVector不同,QLinkedList(鏈表)不支持快速隨機(jī)訪問(wèn),但是它提供了"常量時(shí)間"的插入和刪除.QLinkedList未提供[ ]操作符,所以必須使用迭代器來(lái)遍歷.

需要添加頭文件#include <QtCore/qlinkedlist.h>

    // QLinkedList 輸入輸出
    QLinkedList<double> qlink;
    qlink.append(12);
    qlink.append(14);
 
    QLinkedList<double>::iterator i = qlink.begin();
    for (; i != qlink.end(); ++i)
    {
        std::cout << " qlink = " << *i << std::endl;
    }

QList<T>

QList連續(xù)容器是一個(gè)數(shù)組列表,結(jié)合了QVector和QLinkedList的優(yōu)點(diǎn),支持隨機(jī)訪問(wèn),在任意一端插入或者刪除都非??焖?

需要添加頭文件#include <QtCore/qlist.h>

    // Qlist 
    QList<double> qlint;
    qlint.append(15);
    qlint.push_back(17);
    
    std::cout << "qlint = " << qlint[0] << std::endl;
    std::cout << "qlint = " << qlint[1] << std::endl;

注意的是,Qt的容易雖然和STL的不太一樣,但是Qt容器兼容STL的函數(shù)名,比如push_back這是STL容器的添加函數(shù),但是Qt也是支持這個(gè)方法的,其實(shí)底層push_back就是調(diào)用append函數(shù)的.

QStringList

QStringList類是被廣泛應(yīng)用于Qt應(yīng)用編程接口的QList<QString>的子類.除了從它的基類繼承的函數(shù)以外,QStringList還提供了一些特別的函數(shù).以使得這種類對(duì)字符串的處理方式更通用.

總結(jié)

對(duì)于所有的容器類,值類型T可以是一個(gè)與int, double,指針類型,具有默認(rèn)構(gòu)造函數(shù)的類(沒(méi)有參數(shù)的構(gòu)造函數(shù)),拷貝構(gòu)造函數(shù)或者賦值操作符相似的類.符合這個(gè)條件的類包括: QByteArray,QDateTime,QRegExp,QString和QVariant.

派生自QObject的Qt類不具備資格,因?yàn)樗麄儧](méi)有拷貝構(gòu)造函數(shù)和賦值操作符.這在實(shí)際應(yīng)用中并不是問(wèn)題,因?yàn)榭梢院?jiǎn)單的存儲(chǔ)指向QObject類的指針而不是對(duì)象本身.

為了能使隱含共享的作用發(fā)揮到最好,可以采取兩個(gè)編程習(xí)慣

第一種:

對(duì)于一個(gè)向量或者列表進(jìn)行讀取時(shí)采用at()函數(shù),而不是[ ]操作符.因?yàn)镼t不能分辨 [ ]操作符是讀取還是賦值.而at() 函數(shù)則不被允許賦值.

第二種:

使用STL風(fēng)格的迭代器遍歷容器的時(shí)候經(jīng)可能的使用const_iterator, constBegin()和constEnd().

此外:Qt還提供了foreach循環(huán).

    // foreach 使用
    foreach (double var , qlint)
    {
        std::cout << "foreach qlint = " << var << std::endl;
    }
    for each (double var in qlint)
    {
        std::cout << "STL  foreach qlint = " << var << std::endl;
    }
    for (auto& var : qlint)
    {
        std::cout << "C++11  foreach qlint = " << var << std::endl;
    }

當(dāng)然C++ 11 以后也支持for each 語(yǔ)法上稍有差距.習(xí)慣那個(gè)用哪個(gè).Qt的foreach是Qt自己通過(guò)宏定義自己封裝的,而for each是C++11原生支持的,現(xiàn)在C++版本都支持,看自己習(xí)慣.

關(guān)聯(lián)容器

關(guān)聯(lián)容器主要是QMap<K,T>和QHash<K,T>

QMap<K,T>

需要添加頭文件#include <QtCore/qmap.h>和#include <QtCore/qhash.h>

在映射中插入項(xiàng)的一點(diǎn)簡(jiǎn)單方式是調(diào)用insert():[ ]操作符既可以用于檢索也可以用于插入.如果在非常量映射中使用[ ]為一個(gè)不存在的鍵檢索值,則會(huì)給定的鍵和空值創(chuàng)建一個(gè)新的項(xiàng).為了避免意外的創(chuàng)建空的值可以使用value()函數(shù)來(lái)代替[ ]操作符來(lái)獲取項(xiàng).

    // Qmap操作
    QMap<QString, int> map;
    map.insert("123",123);
    map.insert("1",1);
    map.insert("2",2);
    map["3"] = 3;
    map["4"] = 4;
 
    int val = map.value("123");
    std::cout << "map val = " << val << std::endl;

QMap有一對(duì)方便的函數(shù),keys()和values()它們?cè)谔幚硇?shù)據(jù)集時(shí)顯得特別有用.他們分別返回映射鍵和映射值.

    QList<QString> strKey = map.keys();
    QList<int> iValue = map.values();
 
    for each (QString var in strKey)
    {
        std::cout << "map key = " << var.toStdString() << std::endl;
    }
    for (auto& var : iValue)
    {
        std::cout << "map value = " << var << std::endl;
    }
    foreach(QString var, strKey)
    {
        std::cout << "map key = " << var.toStdString() << std::endl;
        std::cout << "map value = " << map.value(var) << std::endl;
    }

var.toStdString()這個(gè)是QString轉(zhuǎn)string的函數(shù),map.value(var)這個(gè)是獲取key的value的值.

通過(guò)insertMulti()函數(shù)或者QMultiMap<K,T>的子函數(shù)可以讓多個(gè)鍵值對(duì)有相同的鍵.

字符串,字節(jié)數(shù)組,變量操作

QString,QByteArray和QVariant 這三種類與容器類都有相似之處.有些情況都可以用來(lái)代替容器類.

C++本身提供兩種形式的字符串,一種是以'\0'結(jié)尾的字符數(shù)組和std::string類.與這兩種字符串不同,QString支持16位Unicode值.Unicode碼以ASCII碼和Latin-1碼為子集可以表示世界上對(duì)大多數(shù)的語(yǔ)言.

字符串拼接

    // 字符串拼接
 
    QString str;
 
    str = "123" + QString("qwe");
    str += "asf";
    str.append("zzxc");
    std::cout << "str = " << str.toStdString() << std::endl;
    str.sprintf("%s %.1f","poi",123.4);
    std::cout << "str = " << str.toStdString() << std::endl;
    str = QString("%1 %2 (%3 - %4)").arg("rt").arg("gd").arg("vtr").arg("re");

數(shù)字轉(zhuǎn)字符串

QString nstr = QString::number(123);

字符串轉(zhuǎn)數(shù)字

    auto a = nstr.toInt();
    auto a = nstr.toDouble();
    auto a = nstr.toLongLong();

字符串截取

    QString astr = "polluter pays principle";
    std::cout << "astr = " << astr.mid(9,4).toStdString() << std::endl;
    std::cout << "astr = " << astr.mid(9).toStdString() << std::endl;
    std::cout << "astr = " << astr.left(8).toStdString() << std::endl;
    std::cout << "astr = " << astr.right(9).toStdString() << std::endl;

輸出pays mid的參數(shù)第一個(gè)是從字符串第幾個(gè)開(kāi)始截取,第二個(gè)參數(shù)是截取幾個(gè)字符,當(dāng)然第二個(gè)參數(shù)沒(méi)有就是截取到最后.left()函數(shù)是從左邊截取幾個(gè)字符,參數(shù)就是截取的數(shù)量,right()函數(shù)也是一樣的,從右邊截取.

字符串查詢是否包含某個(gè)子字符串

    QString bstr = "the middle bit";
    std::cout << "pos = " << bstr.indexOf("middle") << std::endl;
    if (bstr.startsWith("the"))
    {
        
    }
    if (bstr.endsWith("bit"))
    {
    
    }

indexOf()函數(shù)查詢bstr是否包含"middle"子字符串.如果包含返回字符串位置,如果只想檢查是否以某個(gè)字符串開(kāi)始,以某個(gè)字符串結(jié)束,可以使用startsWith()和endsWith()

字符串替換

    bstr.replace(0,3,"The");
    std::cout << "bstr = " << bstr.toStdString() << std::endl;
    bstr.replace("the", "The");
    std::cout << "bstr = " << bstr.toStdString() << std::endl;

replace()函數(shù)第一個(gè)參數(shù)是字符串從第幾個(gè)開(kāi)始,第二個(gè)參數(shù)是結(jié)束位置,第三個(gè)是替換的字符串.

第二重載版本就比較簡(jiǎn)單了,第一個(gè)參數(shù)是需要被替換的字符串,第二個(gè)是替換的字符串.兩個(gè)字符串不一定長(zhǎng)度一樣,不一樣也可以.

字符串刪除多余的空格

刪除字符串兩端的空格

    QString cstr = "  BOB \t THE  \nDOG \n";
    std::cout << "bstr = " << cstr.trimmed().toStdString() << std::endl;

trimmed()函數(shù)刪除字符串兩端的空格.

刪除字符串內(nèi)部連續(xù)的空格

std::cout << "bstr = " << cstr.simplified().toStdString() << std::endl;

simplified()函數(shù)刪除字符串內(nèi)部連續(xù)的空格.

把一個(gè)字符串分成一些QStringList字串

    QString dstr = "polluter pays principle";
    QStringList qlst = dstr.split(" ");
    std::cout << "qlst length = " << qlst.length() << std::endl;
    for each (QString var in qlst)
    {
        std::cout << "var = " << var.toStdString() << std::endl;
    }

split()函數(shù)把QString分成QStringList,參數(shù)就是按那個(gè)字符分,demo是按" "空格字符分的.

將QStringList拼接成QString

    QString estr = qlst.join("\n");
    std::cout << "estr = " << estr.toStdString() << std::endl;

join()函數(shù)把QStringList拼接成QString,中間參數(shù)是要加的字符,如果不加用""空的就行,我加了\n比較好看.

其他簡(jiǎn)單的小函數(shù)

length() 函數(shù)返回字符串長(zhǎng)度

isEmpty() 判斷字符串是否為空

實(shí)驗(yàn)所有的代碼

實(shí)驗(yàn)環(huán)境使用VS2015+qt5.9,使用Qt控制臺(tái)輸出的.實(shí)驗(yàn)都可以輸出正確結(jié)果

#include <QtCore/QCoreApplication>
#include <QtCore/qvector.h>
#include <QtCore/qlinkedlist.h>
#include <QtCore/qalgorithms.h>
#include <QtCore/qmap.h>
#include <QtCore/qhash.h>
#include <QtCore/qlist.h>
#include <iostream>
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    std::cout << "hello world" << std::endl;    
    // 初始化定義向量大小
    QVector<double> qvect(3);
    qvect[0] = 0.1;
    qvect[1] = 0.2;
    qvect[2] = 0.3;
    // 初始化未定義向量
    QVector<double> qvect1;
    qvect1.append(0.001);
    qvect1.append(0.002);
    qvect1.append(0.003);
    // 初始化定義向量大小
    QVector<double> qvect2(3);
    qvect2.append(0.22);
    qvect2.append(0.21);
    qvect2.append(0.23);
    qvect2.append(0.24);
 
    // QLinkedList 輸入輸出
    QLinkedList<double> qlink;
    qlink.append(12);
    qlink.append(14);
 
    QLinkedList<double>::iterator i = qlink.begin();
    for (; i != qlink.end(); ++i)
    {
        std::cout << " qlink = " << *i << std::endl;
    }
 
    // Qlist 
    QList<double> qlint;
    qlint.append(15);
    qlint.push_back(17);
    
    std::cout << "qlint = " << qlint[0] << std::endl;
    std::cout << "qlint = " << qlint[1] << std::endl;
    // foreach 使用
    foreach (double var , qlint)
    {
        std::cout << "foreach qlint = " << var << std::endl;
    }
 
    for each (double var in qlint)
    {
        std::cout << "STL  foreach qlint = " << var << std::endl;
    }
    for (auto& var : qlint)
    {
        std::cout << "C++11  foreach qlint = " << var << std::endl;
    }
 
    // Qmap操作
    QMap<QString, int> map;
    map.insert("123",123);
    map.insert("1",1);
    map.insert("2",2);
    map["3"] = 3;
    map["4"] = 4;
 
    int val = map.value("123");
    std::cout << "map val = " << val << std::endl;
 
    QList<QString> strKey = map.keys();
    QList<int> iValue = map.values();
 
    for each (QString var in strKey)
    {
        std::cout << "map key = " << var.toStdString() << std::endl;
    }
    for (auto& var : iValue)
    {
        std::cout << "map value = " << var << std::endl;
    }
 
    foreach(QString var, strKey)
    {
        std::cout << "map key = " << var.toStdString() << std::endl;
        std::cout << "map value = " << map.value(var) << std::endl;
    }
 
    // 字符串拼接
 
    QString str;
 
    str = "123" + QString("qwe");
    str += "asf";
    str.append("zzxc");
    std::cout << "str = " << str.toStdString() << std::endl;
    str.sprintf("%s %.1f","poi",123.4);
    std::cout << "str = " << str.toStdString() << std::endl;
    str = QString("%1 %2 (%3 - %4)").arg("rt").arg("gd").arg("vtr").arg("re");
    
    std::cout << "str = " << str.toStdString() << std::endl;
 
 
    QString nstr = QString::number(123);
    
 
    QString astr = "polluter pays principle";
    std::cout << "astr = " << astr.mid(9,4).toStdString() << std::endl;
    std::cout << "astr = " << astr.mid(9).toStdString() << std::endl;
    std::cout << "astr = " << astr.left(8).toStdString() << std::endl;
    std::cout << "astr = " << astr.right(9).toStdString() << std::endl;
 
    QString bstr = "the middle bit";
    std::cout << "pos = " << bstr.indexOf("middle") << std::endl;
 
    if (bstr.startsWith("the"))
    {
        
    }
    if (bstr.endsWith("bit"))
    {
    
    }
 
    bstr.replace(0,3,"The");
    std::cout << "bstr = " << bstr.toStdString() << std::endl;
    bstr.replace("the", "The");
    std::cout << "bstr = " << bstr.toStdString() << std::endl;
 
    QString cstr = "  BOB \t THE  \nDOG \n";
    std::cout << "bstr = " << cstr.trimmed().toStdString() << std::endl;
    std::cout << "bstr = " << cstr.simplified().toStdString() << std::endl;
 
 
    QString dstr = "polluter pays principle";
    QStringList qlst = dstr.split(" ");
    std::cout << "qlst length = " << qlst.length() << std::endl;
    for each (QString var in qlst)
    {
        std::cout << "var = " << var.toStdString() << std::endl;
    }
 
    QString estr = qlst.join("\n");
    std::cout << "estr = " << estr.toStdString() << std::endl;
    return a.exec();
}

結(jié)果

到此這篇關(guān)于Qt學(xué)習(xí)之容器的使用詳解的文章就介紹到這了,更多相關(guān)Qt容器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)順序表的實(shí)現(xiàn)代碼

    C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)順序表的實(shí)現(xiàn)代碼

    這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)順序表的實(shí)現(xiàn)代碼的相關(guān)資料,動(dòng)態(tài)順序表在內(nèi)存中開(kāi)辟一塊空間,可以隨我們數(shù)據(jù)數(shù)量的增多來(lái)擴(kuò)容,需要的朋友可以參考下
    2017-08-08
  • Qt使用QCamera實(shí)現(xiàn)切換相機(jī),分辨率和圖像捕獲功能

    Qt使用QCamera實(shí)現(xiàn)切換相機(jī),分辨率和圖像捕獲功能

    這篇文章主要為大家介紹了如何利用Qt中的相機(jī)類QCamera,取景器類QCameraViewfinder,圖像捕獲類QCameraImageCapture實(shí)現(xiàn)切換相機(jī)、分辨率和圖像捕獲功能,需要的可以了解一下
    2023-04-04
  • 解析wprintf 中使用%I64d格式化輸出LONGLONG的詳細(xì)介紹

    解析wprintf 中使用%I64d格式化輸出LONGLONG的詳細(xì)介紹

    本篇文章是對(duì)wprintf 中使用%I64d格式化輸出LONGLONG進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • Qt編寫地圖綜合應(yīng)用之繪制覆蓋物折線

    Qt編寫地圖綜合應(yīng)用之繪制覆蓋物折線

    折線圖目前應(yīng)用最廣的也是用來(lái)繪制各種軌跡,折線圖其實(shí)就是后面動(dòng)態(tài)軌跡圖、飛機(jī)航線圖的前身,公用的一個(gè)方法addPolyline。本文將教大家如何通過(guò)QT實(shí)現(xiàn)覆蓋物折線圖,快來(lái)學(xué)習(xí)吧
    2021-12-12
  • C++?棧和隊(duì)列的實(shí)現(xiàn)超詳細(xì)解析

    C++?棧和隊(duì)列的實(shí)現(xiàn)超詳細(xì)解析

    棧和隊(duì)列,嚴(yán)格意義上來(lái)說(shuō),也屬于線性表,因?yàn)樗鼈円捕加糜诖鎯?chǔ)邏輯關(guān)系為?"一對(duì)一"?的數(shù)據(jù),但由于它們比較特殊,因此將其單獨(dú)作為一章,做重點(diǎn)講解
    2022-03-03
  • C++ 中

    C++ 中"emplace_back" 與 "push_back" 的區(qū)別

    這篇文章主要介紹了C++ 中"emplace_back" 與 "push_back" 的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • 深入探討POJ 2312 Battle City 優(yōu)先隊(duì)列+BFS

    深入探討POJ 2312 Battle City 優(yōu)先隊(duì)列+BFS

    本篇文章是對(duì)優(yōu)先隊(duì)列+BFS進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 關(guān)于C++的強(qiáng)制類型轉(zhuǎn)換淺析

    關(guān)于C++的強(qiáng)制類型轉(zhuǎn)換淺析

    C++的強(qiáng)制類型轉(zhuǎn)換是我們?cè)谌粘i_(kāi)發(fā)中經(jīng)常會(huì)遇到的,下面這篇文章主要給大家介紹了關(guān)于C++強(qiáng)制類型轉(zhuǎn)換的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • boost.asio框架系列之調(diào)度器io_service

    boost.asio框架系列之調(diào)度器io_service

    這篇文章介紹了boost.asio框架系列之調(diào)度器io_service,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • C語(yǔ)言的程序環(huán)境與預(yù)處理你真的了解嗎

    C語(yǔ)言的程序環(huán)境與預(yù)處理你真的了解嗎

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言的程序環(huán)境與預(yù)處理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02

最新評(píng)論