日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Qt工作笔记-QVector下标访问和迭代访问效率实践(大跌狗眼)

發(fā)布時間:2025/3/15 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Qt工作笔记-QVector下标访问和迭代访问效率实践(大跌狗眼) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

IDE為Qt Creator 版本為5.7

編譯器為MinGW

這個實驗感覺與編譯器有關(優(yōu)化)Debug和Release也有關

?

下面所有的過程都是以Debug版本進行!!!!

程序界面很low,如下圖:

?

變量100086個數(shù)據(jù),并使用qDebug()進行輸出

?

使用iterator運行截圖如下:

?

使用sub運行截圖如下:

?

本人運行了多次,這絕非偶然,使用iterator比sub快一倍左右。

?

總結(jié)下:

當數(shù)據(jù)量大的情況下,如果使用QVector,那么遍歷的時候,優(yōu)先考慮迭代吧!

當數(shù)據(jù)量大的情況下,如果使用QVector,那么遍歷的時候,優(yōu)先考慮迭代吧!

當數(shù)據(jù)量大的情況下,如果使用QVector,那么遍歷的時候,優(yōu)先考慮迭代吧!

?

可能結(jié)論不準確,因為是MinGw的編譯器,并且還是Debug版本的

?

源碼如下:

widget.h

#ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QVector>namespace Ui { class Widget; }class Widget : public QWidget {Q_OBJECTpublic:explicit Widget(QWidget *parent = 0);~Widget();public slots:void iteratorBtnClicked();void subBtnClicked();private:Ui::Widget *ui;QVector<QString> m_strVec; };#endif // WIDGET_H

widget.cpp

#include "widget.h" #include "ui_widget.h" #include <QDebug> #include <ctime> #include <QTime> #include <QMessageBox>Widget::Widget(QWidget *parent) :QWidget(parent),ui(new Ui::Widget) {ui->setupUi(this);connect(ui->vectorItPushButton,SIGNAL(clicked(bool)),this,SLOT(iteratorBtnClicked()));connect(ui->vectorSubPushButton,SIGNAL(clicked(bool)),this,SLOT(subBtnClicked()));qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));for(int i=0;i<100086;i++){m_strVec.append("I am IT"+QString::number(qrand()%(2000-1970)+1970)+"!");} }Widget::~Widget() {delete ui; }void Widget::iteratorBtnClicked() {//traverse it againclock_t start,finish;double totalTime;start=clock();QVector<QString>::iterator it=m_strVec.begin(); // while(it!=m_strVec.end()){ // qDebug()<<*it; // it++; // }for(;it!=m_strVec.end();it++){qDebug()<<*it;it++;}finish=clock();totalTime=(double)(finish-start)/CLOCKS_PER_SEC;QMessageBox::information(this,"information","using sub traverse takes "+QString::number(totalTime,'f',6)); }void Widget::subBtnClicked() {//traverse it againclock_t start,finish;double totalTime;start=clock();for(int i=0;i<m_strVec.size();i++){qDebug()<<m_strVec[i];}finish=clock();totalTime=(double)(finish-start)/CLOCKS_PER_SEC;QMessageBox::information(this,"information","using sub traverse takes "+QString::number(totalTime,'f',6)); }

main.cpp

#include "widget.h" #include <QApplication>int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); }

?

總結(jié)

以上是生活随笔為你收集整理的Qt工作笔记-QVector下标访问和迭代访问效率实践(大跌狗眼)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。