QT容器类,相对于C++的STL容器类,更为小巧、安全和方便使用。QT5在容器类里面做了优化速度、内存、inline等操作。
QT5容器类:QList、QLinkedList、QVector、QMap、QHash、QVariant类等。
QT5容器类中,容器可以存储的数据有:
1、基本数据类型,如int、float等。
2、QT的一些数据类型,比如QString、QDate、QTime等。
切记:QObject和其子类,不能作为容器数据,比如QWidget、QDialog等。
QT5中的迭代器iterator有两种风格:Java和STL风格,考虑到效率和兼容性问题,我们建议使用STL风格。
QList
QList是最常用的容器类,它内部维护的一组指针数组,数组里面的每个指针,指向实际存储的对象,所以,QList是支持随机访问,也就是可以通过下标[]访问,
与我们平时访问一维数组是一样的道理,这极大的方便了QList的使用。这和C++中STL的list是不一样的,STL中的list是双向链表,是不支持随机访问,内存不连续的。
继承自QList的常见类有:QQueue、QStringList、QTestEventList等。
如下是一个实际的例子:
#include <QList>
QList<QString> list;
list<<"hello";
qDebug()<<list[0];
QLinkedList
QLinkedList<>是一个链式列表,它以非连续内存块存储,与C++中STL的list非常类似,插入item很快,但是查找比较慢。
QVector
QVector<>是在相邻的内存区域存储给定数据,这一点和C++ STL中的vector是非常类似的,所以也可以进行随机访问,即下标访问。但是它的插入操作是十分慢的,因为可能造成内存大面积的移动,这一点和QList<>是不同的。
继承自QVector的常见类有:QStack。
QMap和QHash
QMap和QHash的相似度较高,但是还具备以下不同点:
1、QHash的查找速度比QMap快一些。
2、QHash存储的数据是没有顺序的,QMap是按照key顺序来存储。
3、QHash类型的key,key必须要有==操作和qHash(key)全局函数,而QMap的key,其key必须要有<比较操作
QMap<QString,