Qt工作笔记-QVector下标访问和迭代访问效率实践(大跌狗眼)
生活随笔
收集整理的這篇文章主要介紹了
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_Hwidget.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)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++工作笔记-多继承下的一个大坑
- 下一篇: Qt中echo服务器的简单编写