QList是目前最常用的容器类,它存储了给定类型的值的一个列表,而这些值可以通过索引访问。QList使用数组来实现,以确保进行快速的基于索引的访问。
使用QList::append和QList::prepend在列表的两端进行添加项目。
使用QList::insert()在列表的中间插入项目。
实例:
1 #include <QCoreApplication>
2 #include <QList>
3 #include <QDebug>
4 int main(int argc, char *argv[])
5 {
6 QCoreApplication a(argc, argv);
7 QList<QString> list;
8 list << "aa" << "bb" << "cc"; // 插入项目
9 if(list[1] == "bb") list[1] = "ab";
10 list.replace(2, "bc"); // 将“cc”换为“bc”
11 qDebug() << "the list is: "; // 输出整个列表
12 for(int i=0; i<list.size(); ++i){
13 qDebug() << list.at(i); // 现在列表为aa ab bc
14 }
15 list.append("dd"); // 在列表尾部添加
16 list.prepend("mm"); // 在列表头部添加
17 QString str = list.takeAt(2); // 从列表中删除第3个项目,并获取它
18 qDebug() << "at(2) item is: " << str;
19 qDebug() << "the list is: ";
20 for(int i=0; i<list.size(); ++i)
21 {
22 qDebug() << list.at(i); // 现在列表为mm aa bc dd
23 }
24 list.insert(2, "mm"); // 在位置2插入项目
25 list.swap(1,3); // 交换项目1和项目3
26 qDebug() << "the list is: ";
27 for(int i=0; i<list.size(); ++i)
28 {
29 qDebug() << list.at(i); // 现在列表为mm bc mm aa dd
30 }
31 qDebug() << "contains 'mm' ?" << list.contains("mm"); // 列表中是否包含“mm”
32 qDebug() << "the 'mm' count: " << list.count("mm"); // 包含“mm”的个数
33 // 第一个“mm”的位置,默认从位置0开始往前查找,返回第一个匹配的项目的位置
34 qDebug() << "the first 'mm' index: " << list.indexOf("mm");
35 // 第二个“mm”的位置,我们指定从位置1开始往前查找
36 qDebug() << "the second 'mm' index: " << list.indexOf("mm", 1);
37 return a.exec();
38 }
运行输出: