4. Qt的容器类

  Qt提供来一组通用的基于模板的容器类.

一. QList类,QLinkedList类 和  QVector类

        QList类、QLinkedList类和QVector类经常使用到的Qt容器类有QList、QLinkedList和QVector等。在开发一个较高性能需求的应用程序时,程序员会比较关注这些容器类的运行效率,下表列出了QList、QLinkedList和QVector容器的时间复杂度。

其中: "Amort.O(1)"表示仅完成一次操作.可能会有O(n)行为.

(1)QList类

             QList<T>是目前为止最常用的容器类,它存储给定数据类型T的一列数值。继承自QList类的子类QItemSelection、QQueue、QSignalSpy以及QStringList和QTestEventList。

QList提供了可以在列表进行追加的QList::append()和Qlist::prepend()函数,也提供了在列表中间完成插入操作的函数QList::insert()。相对于任何其他的Qt容器类,为了使可执行代码尽可能少,QList被高度优化。

QList<T>维护了一个指针数组,该数组存储的指针指向QList<T>存储的列表项的内容。

#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:  声明一个QList<QString>栈对象.

*   list<<str;    通过操作运算符"<<"将QString 字符串存储在列表中.

(2) QLinkedList 类

             QLinkedList<T>是一个链式列表,它以非连续的内存块保存数据。

QLinkedList<T>不能够使用下标,只能够使用迭代器访问它的数据项。与QList相比,当对一个很大的列表进行插入操作时,QLinkedList具有更高的效率。

(3) QVector 类

     QVector<T>在相邻的内存中存储给定数据类型T的一组数值。在一个QVector的前部或者中间位置进行插入操作的速度是很慢的,这是由QVector存储数据的方式决定的。

STL风格迭代容器类遍历容器

   对于每一个容器类,Qt都提供了两种类型的STL风格迭代器数据类型:一种提供只读访问,一种提供读写访问。由于只读类型的迭代器要比读写迭代器速度更快,所以应尽可能地使用只读类型的迭代器。两种风格迭代器分类如表表示。

<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;// 初始化一个读写迭代器,次为指针类型

   for(i=list.begin();i!=list.end();++i)
   {
       qDebug()<<(*i);
       *i = (*i)*10;
   }

   QList<int>::const_iterator ci;// 初始化一个只读迭代器
   for(ci = list.constBegin();ci != list.constEnd();++ci)
       qDebug()<<*ci;

    return 0;
}

二. QMap类和QHash类

QMap类和QHash类具有非常类似的功能,它们的差别仅在于:

QHash具有比QMap更快的查找速度。

QHash以任意的顺序存储数据项,而QMap总是按照键Key顺序存储数据。

QHash的键类型Key必须提供operator==()和一个全局的qHash(Key)函数,而QMap的键类型Key必须提供operator<()函数。

1 . QMap类

          QMap<Key,T>提供了一个从类型为Key的键到类型为T的值的映射。

QMap存储的数据形式是一个键对应一个值,并且按照键Key的次序存储数据。为了能够支持一键多值的情况,QMap提供了QMap<Key,T>::insertMulti()和QMap<Key,T>::values()函数。存储一键多值的数据时,也可以使用QMultiMap<Key,T>容器,它继承自QMap。

2.QHash类

QHash<Key,T>具有和QMap几乎完全相同的API。QHash维护着一张哈希表(hash table),哈希表的大  小和QHash的数据项的数目相适应。

3. STL风格的迭代器容器遍历

   对于每一个容器类,Qt都提供了两种类型的STL风格迭代器数据类型:一种提供只读访问,一种提供读写访问.

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++的联合(union)数据类型,它能够保存很多Qt类型的值,包括QColor、QBrush、QFont、QPen、QRect、QString、QSize等,也能够存放Qt的容器类型的值。Qt的很多功能都是建立在QVariant基础上的,比如Qt的对象属性以及数据库功能等。

#include <QDebug>
#include <QVariant>
#include <QColor>

int main()
{
    QVariant v(709);// 声明一个QVariant变量v,初始化为整数.
    qDebug()<<v.toInt();  /// 转换为整数,输出

    //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;               // 创建字符串列表
    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>模块提供了一些算法和函数。

int main()
{
    double a = -19.3,b=9.7;
    double c=qAbs(a);   // 返回绝对值
    double max=qMax(b,c);  // 返回最大值

    int bn = qRound(b);  //  四舍五入返回一个整数
    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);   // 交换两个数的值
    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. 基本正则表达式

正则表达式由表达式(expressions)、量词(quantifiers)和断言(assertions)组成。

(1) 最简单的表达式是一个字符。要表示字符集的表达式可以使用类似如“[AEIOU]”表示匹配所有的大写元音字母;使用“[^AEIOU]”则表示匹配所有非元音字母,即辅音字母;连续的字符集使用可以使用表达式如“[a-z]”,表示匹配所有小写英文字母。

(2) 量词说明表达式出现的次数,例如“x[1,2]”表示“x”可以至少有一个,至多两个。

在计算机语言中,标识符通常要求以字母或下画线开头,后面可以是字母、数字和下画线。满足条件的标识符表示为:

" [A-Za-z_]+[A-Za-z_0-9]* "

⑶“^”、“$”、“\b”都是正则表达式的断言

时间: 2024-10-23 04:17:07

4. Qt的容器类的相关文章

Qt中容器类应该如何存储对象

Qt提供了丰富的容器类型,如:QList.QVector.QMap等等.详细的使用方法可以参考官方文档,网上也有很多示例文章,不过大部分文章的举例都是使用基础类型:如int.QString等.如果我们要存储一个对象类型,应该如何做呢?—— 当然是和int类型一样操作,因为这些容器类都是泛型的.不过,我们今天要讨论的不是容器类的使用用法,而是容器存储的对象内存如何释放的问题. (这里提到了对象类型是指 Class/Struct,可以继承自QObject,也可以是普通的C++类.) 下面以QList

Qt之容器类

Qt的顺序容器类:QList.QLinkedList.QVector.QStack和QQueue. 1.QList 以数组列表(array-list)形式实现,以下表索引方式对数据项进行访问. 对数据项的操作函数有:#include <QList> insert().replace().removeAt().move().swap().append().prepend().removeFirst().removeLast().at().begin().end().clear().erase()

Qt容器类之一:Qt的容器类介绍

一.介绍 Qt库提供了一套通用的基于模板的容器类,可以用这些类存储指定类型的项.比如,你需要一个大小可变的QString的数组,则使用QVector<QString>. 这些容器类比STL(C++标准模板库)容器设计得更轻量.更安全并且更易于使用.如果对STL不熟悉,或者倾向于用"Qt的方式",那么你可以使用这些类,而不去使用STL的类. 你可以用两种方式遍历容器内存储的项:Java风格的迭代器和STL风格的迭代器.Java风格的迭代器更易于使用,并且提供了更高级的功能:S

Qt容器类(总结)

Introduction Qt库提供了一组基于模板的一般化的容器类.这些容器可以存储指定的类型的元素.例如,如果你需要一个可变大小的Qstring数组,可以用QVector<QString>.. 这些容器比STL容器更轻更安全更容易使用.如果你不熟悉STL或者更喜欢以Qt的方式做事,你可以用这些类取代STL类. 这些类是隐式共享的,它们都是可重入,它们进行了速度优化,用更少的内存和最小的内联代码扩展,生成更小的可执行文件.此外,当所有的线程仅仅以只读的方式访问它们时,它们是线程安全的. 为了遍

QT开发(二十五)——QT模板库

QT开发(二十五)--QT模板库 一.QTL模板库简介 QT模板库(QT Template Library 简称QTL)是一套提供对象容器的模板. QTL提供了对象的链表.对象的矢量(动态数组).从一个类型到另一个类型的映射(或称为字典)和相关的迭代器和算法.容器是包含和管理其它对象的一个对象,并且提供迭代器对被包含的对象进行访问. 1.QT容器类简介 容器是能够在内存中存储其他特定类型的对象的对象,一般是通用的模板类.QT提供了自己的一套容器类,即在QT的应用程序中,可以使用标准C++的STL

Qt 学习之路:存储容器

存储容器(containers)有时候也被称为集合(collections),是能够在内存中存储其它特定类型的对象,通常是一些常用的数据结构,一般是通用模板类的形式.C++ 提供了一套完整的解决方案,作为标准模板库(Standard Template Library)的组成部分,也就是常说的 STL. Qt 提供了另外一套基于模板的容器类.相比 STL,这些容器类通常更轻量.更安全.更容易使用.如果你对 STL 不大熟悉,或者更喜欢 Qt 风格的 API,那么你就应该选择使用这些类.当然,你也可

Qt 学习之路 2笔记3

Graphics View Framework Graphics View 提供了一种接口,用于管理大量自定义的 2D 图形元素,并与之进行交互:还提供了用于将这些元素进行可视化显示的观察组件,并支持缩放和旋转. Graphics View 框架包含了一套完整的事件体系,可以用于与场景中的元素进行双精度的交互.这些元素同样支持键盘事件.鼠标事件等.Graphics View 使用了 BSP 树(Binary Space Partitioning tree,这是一种被广泛应用于图形学方面的数据结构

用Qt Label 生成矩阵阵列

最近做的一个项目中需要用到视觉去检测产品,产品呈矩阵式排列,客户那边需要检测完一组产品后能够将检测结果以图形化的方式显示出来. emmm,这个似乎不难,只需要有类似于数组的东西就可以搞定,不过对于数组来说它并不能存像QLabel这样的类型,但是Qt它还是机制地提供了几种容器类来帮我们储存数据.Qt的容器类大概有以下几类: QList类(用得比较多的一种):QList.QLinkedList.QQueue QVector类(将数据存储在一段连续的内存空间里):QVector.QStack QMap

QList 和std::list的比较

QList QList<T> 是一个Qt通用容器类.它存储一序列的值,并且提供基于索引的数据访问方法和快速的插入和删除操作. QList<T>, QLinkedList<T>, 和 QVector<T>提供类似的功能,这里进行几点概述: 1.     大多数情况下,最好使用QList.它基于索引的API比QLinkedList基于迭代器的API方便.它存储数据的方式也使得它比QVector存取数据的数度快.而且它在可执行文件中扩展的代码也比较少. 2.