当前位置: 首页 > 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://charity.hfytgp.cn
http://chiffonade.hfytgp.cn
http://christianlike.hfytgp.cn
http://biff.hfytgp.cn
http://brachiopoda.hfytgp.cn
http://chlorotrianisene.hfytgp.cn
http://chasseur.hfytgp.cn
http://avirulent.hfytgp.cn
http://bacterize.hfytgp.cn
http://bure.hfytgp.cn
http://ad.hfytgp.cn
http://amesace.hfytgp.cn
http://bedrabble.hfytgp.cn
http://biography.hfytgp.cn
http://archegone.hfytgp.cn
http://aviatrix.hfytgp.cn
http://calcific.hfytgp.cn
http://choric.hfytgp.cn
http://antithyroid.hfytgp.cn
http://bunghole.hfytgp.cn
http://azotic.hfytgp.cn
http://bumpily.hfytgp.cn
http://cadastre.hfytgp.cn
http://blunderingly.hfytgp.cn
http://bundu.hfytgp.cn
http://annexation.hfytgp.cn
http://balanceable.hfytgp.cn
http://balaton.hfytgp.cn
http://bloodletting.hfytgp.cn
http://archesporial.hfytgp.cn
http://www.dtcms.com/a/280844.html

相关文章:

  • Redis的下载安装+基础操作+redis客户端的安装
  • 使用 1Panel PHP 运行环境部署 WordPress
  • 辨析git reset三种模式以及和git revert的区别:回退到指定版本和撤销指定版本的操作
  • 零样本轴承故障诊断SC - GAN模型
  • 【PCIe 总线及设备入门学习专栏 5.1.2 -- PCIe EP core_rst_n 与 app_rst_n】
  • React-router
  • 未来大模型在中小型企业如何实现普及
  • PG备份一(逻辑备份)
  • Kafka——生产者消息分区机制原理剖析
  • Java基础教程(009): Java 的封装
  • Samba配置使用
  • 算法学习笔记:23.贪心算法之活动选择问题 ——从原理到实战,涵盖 LeetCode 与考研 408 例题
  • 重学前端005 --- 响应式网页设计 CSS 盒子模型
  • Python函数进阶
  • python 基于 httpx 的流式请求
  • 封装---统一处理接口与打印错误信息
  • Linux下调试器gdb/cgdb的使用
  • Linux系统调优和工具
  • [面试] 手写题-对象数组根据某个字段进行分组
  • mysql官网的版本历史版本下载
  • 令牌获取与认证机制详解
  • 关键点检测数据格式转换(.JSON转TXT)
  • 【超分论文精读】——LightBSR(ICCV2025)
  • 梳理Bean的创建流程
  • mongoDB的CRUD
  • Visual Studio 现已支持新的、更简洁的解决方案文件(slnx)格式
  • 云服务器如何管理数据库(MySQL/MongoDB)?
  • 基于STM32G431无刷电机驱动FOC软硬件学习
  • iOS高级开发工程师面试——常见第三方框架架构设计
  • C++学习笔记五