Qt容器类介绍

本文介绍了Qt中包括QList、QLinkedList、QVector等顺序容器和QMap、QHash等关联容器的使用,并通过示例展示了STL风格迭代器的应用,以及通用算法如std::copy、std::equal、std::find等的操作。
摘要由CSDN通过智能技术生成

Qt容器类介绍

Qt提供了一些顺序容器:QList,QLinkedList,QVector,QStack和QQueue。 因为这些容器中的数据都是一个接一个线性存储的,所以称为顺序容器。

Qt还提供了一些关联容器:QMap,QMultiMap,QHash,QMultiHash和QSet。 因为这些容器存储的是<键,值>对,比如QMap<Key,T>,所以称为关联容器。

  1. Qlist

//main.cpp

#include <QCoreApplication>
#include<QList>
#include<QDebug>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    QList<QString>list;
    list<<"aa"<<"bb"<<"cc";                //插入项目
if(list[1]=="bb") list[1]="ab";
list.replace(2,"bc");                      //将"cc"换为"bc"
qDebug()<<"this list is: ";                //输出整个列表
for(int i=0;i<list.size();++i)
{
    qDebug()<<list.at(i);                  //现在列表为aa ab bc
}

list.append("dd");                         //在列表尾部添加
list.prepend("mm");                         //在列表头部添加
QString str=list.takeAt(2);                //从列表中删除第3个项目,并获取它
qDebug()<<"at(2) item is: "<<str;
qDebug()<<"the list is: ";
for(int i=0;i<list.size();++i)
{
    qDebug()<<list.at(i);                   //现在列表为mm aa bc dd

}
list.insert(2,"mm");                        //在位置2插入项目
list.swap(1,3);                             //交换项目1和项目3
qDebug()<<"the list is:";
for(int i=0;i<list.size();++i)
{
    qDebug()<<list.at(i);                   //现在列表为mm bc mm aa dd
}
qDebug()<<"contains 'mm'?"<<list.contains("mm");   //列表中是否包含"mm"
qDebug()<<"the 'mm' count:"<<list.count("mm");     //包含"mm"的个数
//第一个"mm"的位置,默认从位置0开始往前查找,返回第一个匹配的项目的位置
qDebug()<<"the first 'mm' index: "<<list.indexOf("mm");
//第二个"mm"的位置,我们指定从位置1开始往前查找
qDebug()<<"the second 'mm' index: "<<list.indexOf("mm",1);
    return a.exec();
}

程序运行结果:

this list is:

"aa"

"ab"

"bc"

at(2) item is:  "ab"

the list is:

"mm"

"aa"

"bc"

"dd"

the list is:

"mm"

"bc"

"mm"

"aa"

"dd"

contains 'mm'? true

the 'mm' count: 2

the first 'mm' index:  0

the second 'mm' index:  2

 

  1. QMap

//main.cpp

#include <QCoreApplication>
#include<QMap>
#include<QMultiMap>
#include<QDebug>

int main(int argc, char *argv
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WUYANGEZRA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值