当前位置: 首页 > news >正文

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;          // 存储 intQList<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

http://www.lryc.cn/news/589101.html

相关文章:

  • SpringBoot3.0 +GraalVM17 + Docker
  • AI大模型训练相关函数知识补充
  • MongoDB基础增删改查命令
  • vscode配置运行完整C代码项目
  • B/S 架构通信原理详解
  • 高标准农田气象站的功能
  • 亚矩阵云手机:破解 Yandex 广告平台多账号风控难题的利器
  • 云服务器如何管理数据库(MySQL/MongoDB)?
  • 《大数据技术原理与应用》实验报告四 MapReduce初级编程实践
  • Keepalived双机热备概述
  • 死锁问题以及读写锁和自旋锁介绍【Linux操作系统】
  • Sersync和Rsync部署
  • 免杀学习篇(1)—— 工具使用
  • Dify的默认端口怎么修改
  • 算法学习day16----Python数据结构--模拟队列
  • Nuxt3宝塔PM2管理器部署
  • linux系统------LVS+KeepAlived+Nginx高可用方案
  • LVS(Linux Virtual Server)详细笔记(理论篇)
  • 李宏毅《生成式人工智能导论》 | 第9讲 AI Agent
  • Jfinal+SQLite java工具类复制mysql表数据到 *.sqlite
  • 设计模式笔记_结构型_适配器模式
  • Redis 中的持久化机制:RDB 与 AOF
  • 基于STM32设计的智能厨房
  • redis快速入门教程
  • JavaScript进阶篇——第四章 解构赋值(完全版)
  • Bash shell用法
  • 轻松管理多个Go版本:g工具安装与使用
  • 【自学linux】计算机体系结构和操作系统第二章
  • OpenCV 伽马校正函数gammaCorrection()
  • PG备份一(逻辑备份)