QT——QList的详细讲解

QList 是 Qt 框架中一个常用的模板类容器,用于存储和管理一组元素。它类似于 C++ 标准库中的 std::vector,但针对 Qt 的使用场景进行了优化,特别是在内存布局性能方面。


1. QList 的基本概念

1.1 QList 的特点

  • 动态数组QList 是一个动态数组,可以动态调整大小。
  • 高效随机访问:支持 [] 操作符快速访问元素(类似 std::vector)。
  • 快速插入/删除:在列表头部和尾部插入/删除元素非常高效(O(1) 时间复杂度)。
  • 隐式共享(Copy-on-Write):多个 QList 可以共享相同的数据,只有在修改时才会复制数据,提高性能。
  • 支持 Qt 的数据类型:可以直接存储 QStringQVariantQObject* 等 Qt 类型。

1.2 QList 与 QVector 的区别

特性QListQVector
内存布局存储指针(间接访问)连续内存(直接访问)
随机访问性能稍慢(需要解引用)更快(直接访问)
插入/删除性能头部/尾部 O(1),中间 O(n)尾部 O(1),头部/中间 O(n)
适用场景频繁在头部插入/删除频繁随机访问

推荐

  • 如果需要频繁在头部插入/删除,用 QList
  • 如果需要频繁随机访问,用 QVector 或 std::vector

2. QList 的基本用法

2.1 创建 QList

#include <QList>
#include <QString>

int main() {
    QList<int> intList;          // 存储 int
    QList<QString> stringList;   // 存储 QString

    // 初始化列表
    QList<int> numbers = {1, 2, 3, 4, 5};
}

2.2 添加元素

QList<QString> names;
names.append("Alice");  // 在尾部添加
names.prepend("Bob");   // 在头部添加
names.insert(1, "Charlie"); // 在索引 1 处插入

// 也可以使用 << 运算符
names << "Dave" << "Eve";

2.3 访问元素

QList<int> numbers = {10, 20, 30, 40, 50};

// 随机访问
int first = numbers.first();  // 10
int last = numbers.last();    // 50
int third = numbers.at(2);    // 30(越界会检查)
int fourth = numbers[3];      // 40(不检查越界)

// 遍历
for (int i = 0; i < numbers.size(); ++i) {
    qDebug() << numbers[i];
}

// 范围遍历(C++11 风格)
for (int num : numbers) {
    qDebug() << num;
}

2.4 删除元素

QList<int> numbers = {1, 2, 3, 4, 5};

numbers.removeFirst();  // 删除第一个元素(1)
numbers.removeLast();   // 删除最后一个元素(5)
numbers.removeAt(1);    // 删除索引 1 的元素(3)
numbers.removeOne(4);   // 删除第一个匹配的 4

// 清空列表
numbers.clear();

2.5 查找元素

QList<QString> names = {"Alice", "Bob", "Charlie"};

int index = names.indexOf("Bob");    // 返回 1
bool contains = names.contains("Dave"); // 返回 false

2.6 排序

QList<int> numbers = {3, 1, 4, 1, 5, 9};
std::sort(numbers.begin(), numbers.end()); // 升序排序
// 或使用 Qt 的排序
qSort(numbers.begin(), numbers.end()); // Qt5 及之前

3. QList 与 QVector 的选择

场景推荐容器
频繁在头部插入/删除QList
频繁随机访问QVector
存储小型对象(如 int、指针)QList(更高效)
存储大型对象(如结构体)QVector(连续内存更友好)

4. 总结

特性说明
动态数组可动态调整大小
高效头部操作prepend()removeFirst() 是 O(1)
隐式共享多个 QList 可以共享数据,减少复制开销
适用 Qt 类型特别适合存储 QStringQVariant 等 Qt 类型
与 STL 兼容支持 begin()end(),可与 <algorithm> 结合使用

QList 是 Qt 中最常用的容器之一,适合大多数动态数组场景。如果需要更高的随机访问性能,可以考虑 QVector;如果需要频繁中间插入/删除,可以考虑 QLinkedList

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

hardStudy_h

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

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

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

打赏作者

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

抵扣说明:

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

余额充值