Qt 常见容器类用法(一)

目录

QMap类

QHash类

QVector类


QMap类

QMap提供一个从类型为Key的键到类型为T的值的映射。通常,QMap存储的数据形式是一个键对应一个值,并且按照键Key的次序存储数据。为了能够支持一键多值的情况,QMap提供QMap::insertMulti()和QMap::values()函数。QMultiMap类来实例化一个QMap对象

#include 

#include 

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    
    //QMap类
    //1.创建QMap示例,第一个参数为QString类型的键,第二个参数为int类型的值
    QMap qmap;

    // 插入数据信息,他有两种方式操作
    qmap["Chinese"]=119;
    qmap["English"]=120;
    qmap.insert("Math",115);
    qmap.insert("Physics",99);
    qmap.insert("Chemistry",100);
    qDebug()< itr(qmap);
    while(itr.hasNext())      // 在while循环中,使用hasNext()函数检查是否还有下一个键值对待迭代。
    {
        itr.next();            // 调用next()函数将迭代器移动到下一个键值对,并可以通过key()和value()函数获取当前键和值的信息。
        qDebug()<::const_iterator是QMap的常量迭代器类型,用于遍历QMap中的键值对。
    QMap::const_iterator stritr=qmap.constBegin();   // 通过调用constBegin()函数获取QMap的起始迭代器,并将其赋值给stritr。
    while(stritr!=qmap.constEnd())  // 在while循环中,使用stritr != qmap.constEnd() 条件判断是否还有下一个键值对待迭代。
    {
        qDebug()<来查找
    qDebug()<T:"<key:"< aKeys=qmap.keys();
    qDebug()< aValues=qmap.values();
    qDebug()< mulmap;
    mulmap.insert("student","no");
    mulmap.insert("student","name");
    mulmap.insert("student","sex");
    mulmap.insert("student","age");
    mulmap.insert("student","high");
    mulmap.insert("student","weight");
    qDebug()<

结果如下:

Qt 常见容器类用法(一)_第1张图片

QHash类

QHash具有与QMap几乎完全相同的API。QHash维护者一张哈希表(Hash Table),哈希表的大小与QHash的数据项的数据相适应。QHash以任意的顺序组织它的数据,当存储数据的顺序无关紧要时,建议使用QHash作为存放数据的容器。

#include 

#include 

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    QHash qhash;

    qhash["key 1"] = 3;
    qhash["key 2"] = 8;
    qhash["key 3"] = 4;
    qhash["key 4"] = 2;

    qhash.insert("key 3",30);
    QList list=qhash.keys();
    for(int i=0;i hash;
    hash["key 1"]=33;
    hash["key 2"]=44;
    hash["key 3"]=55;
    hash["key 4"]=66;
    hash.insert("key 3",100);

    QHash::const_iterator iterator;
    for(iterator=hash.begin();iterator!=hash.end();iterator++)
        qDebug()<"<

结果如下: 

Qt 常见容器类用法(一)_第2张图片

QMap 与 QHash 区别:

  • QHash 与 QMap 的功能差不多,但 QHash 的查找速度更快
  • QMap 是按照键的顺序存储数据,而QHash 是任意顺序存储的
  • QMap的键必须提供 "<" 运算符,而QHash的键必须提供”==“运算符和一个名为qhash()的全局散列函数

QVector类

QVector在相邻的内存当中存储给定数据类型T的一组数值,在一个QVector的前部或者中间位置进行插入操作的速度是很慢的,这是因为这样的操作将导致内存中大量数据被移动,这是由QVector存储数据的方式决定的。

#include 

#include 

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    // QVector是Qt的一个容器类
    QVector qvr;
    // 第一种赋值方式
    qvr<<10;
    qvr<<20;
    qvr<<30;
    qvr<<40;
    // 第二种赋值方式
    qvr.append(50);
    qvr.append(60);
    qvr.append(70);
    qvr.append(80);
    qvr.append(90);
    qvr.append(100);

    qDebug()<<"qvr count="<Qt 常见容器类用法(一)_第3张图片

你可能感兴趣的:(QT,qt)