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

Qt基础:数据容器类

数据容器类

  • 1. QList
    • 1.1 使用
      • 创建和初始化
      • 添加和删除元素
      • 访问和修改元素
      • 查找和判断元素
      • 遍历列表
      • 排序和筛选
      • 与其他容器的转换
    • 1.2 完整示例

1. QList

在Qt中,QList 是一个动态数组容器类,用于存储和管理相同类型的元素。它提供了快速随机访问、动态扩展和丰富的操作方法,是Qt中最常用的容器类之一。

  • 功能:实现动态数组,支持快速随机访问和动态增长。
  • 底层实现:基于数组,在元素数量超过预分配空间时自动重新分配内存。
  • 特点
    • 支持索引访问(如 list[0])。
    • 可动态添加、删除元素。
    • 提供多种遍历方式。
    • 元素类型必须是可赋值的(如基本类型、QString、自定义类等)。

性能考虑:

  • 随机访问:O(1),非常高效。
  • 尾部插入/删除:平均O(1),但可能需要重新分配内存。
  • 中间插入/删除:O(n),因为需要移动后续元素。
  • 查找:O(n),线性查找。

如果需要频繁在中间插入/删除元素,可考虑使用 QLinkedList;如果需要键值对存储,可使用 QMapQHash

1.1 使用

创建和初始化

#include <QList>
#include <QString>// 创建空列表
QList<int> intList;
QList<QString> stringList;// 使用初始化列表创建
QList<int> numbers = {1, 2, 3, 4, 5};
QList<QString> names = {"Alice", "Bob", "Charlie"};// 从现有列表复制
QList<int> copyList(numbers);  // 深拷贝// 指定初始大小和值
QList<QString> emptyNames(5, "");  // 创建包含5个空字符串的列表

添加和删除元素

// 添加元素
QList<QString> list;
list.append("Apple");      // 在末尾添加
list.prepend("Banana");    // 在开头添加
list.insert(1, "Cherry");  // 在索引1处插入// 删除元素
list.removeAt(1);          // 删除索引1的元素
list.removeFirst();        // 删除第一个元素
list.removeLast();         // 删除最后一个元素
list.removeOne("Apple");   // 删除第一个匹配的元素
list.removeAll("Apple");   // 删除所有匹配的元素// 清空列表
list.clear();

访问和修改元素

// 通过索引访问(不检查边界)
QString first = list[0];   // 读取
list[0] = "New Value";     // 修改// 通过at()访问(检查边界,越界时抛出异常)
QString second = list.at(1);// 获取列表大小
int size = list.size();    // 或 list.count()// 判断列表是否为空
bool isEmpty = list.isEmpty();  // 或 list.size() == 0// 获取第一个和最后一个元素
QString firstItem = list.first();  // 或 list.front()
QString lastItem = list.last();    // 或 list.back()

查找和判断元素

// 查找元素位置(返回第一个匹配的索引,未找到返回-1)
int index = list.indexOf("Apple");
int lastIndex = list.lastIndexOf("Apple");// 判断是否包含元素
bool containsApple = list.contains("Apple");// 统计元素出现次数
int count = list.count("Apple");

遍历列表

基于索引的遍历

for (int i = 0; i < list.size(); ++i) {qDebug() << list[i];
}

基于迭代器的遍历

// 只读迭代器
QList<QString>::const_iterator it;
for (it = list.constBegin(); it != list.constEnd(); ++it) {qDebug() << *it;
}// 读写迭代器
QList<QString>::iterator mutableIt;
for (mutableIt = list.begin(); mutableIt != list.end(); ++mutableIt) {*mutableIt = "Modified";
}

C++11范围for循环

for (const QString &item : list) {qDebug() << item;
}// 可修改的版本
for (QString &item : list) {item = "Modified";
}

排序和筛选

// 排序(升序)
QList<int> numbers = {3, 1, 4, 2};
std::sort(numbers.begin(), numbers.end());  // 标准库排序// 自定义排序(降序)
std::sort(numbers.begin(), numbers.end(), [](int a, int b) {return a > b;
});// 筛选元素(使用STL算法)
QList<int> evenNumbers;
std::copy_if(numbers.begin(), numbers.end(), std::back_inserter(evenNumbers),[](int num) { return num % 2 == 0; });

与其他容器的转换

// QList 转 QVector
QVector<int> vector = numbers.toVector();// QList 转 std::list
std::list<int> stdList = numbers.toStdList();// std::vector 转 QList
std::vector<double> stdVector = {1.1, 2.2, 3.3};
QList<double> qList = QList<double>::fromStdVector(stdVector);

1.2 完整示例

#include <QList>
#include <QDebug>void listExample() {// 创建列表并添加元素QList<QString> fruits;fruits.append("Apple");fruits.append("Banana");fruits.prepend("Cherry");// 遍历列表qDebug() << "所有水果:";for (const QString &fruit : fruits) {qDebug() << fruit;}// 修改元素if (fruits.size() > 1) {fruits[1] = "Blueberry";}// 查找元素int index = fruits.indexOf("Apple");if (index != -1) {qDebug() << "找到Apple,索引为:" << index;}// 删除元素fruits.removeOne("Cherry");// 排序fruits.sort();// 输出排序后的列表qDebug() << "排序后的水果:";for (const QString &fruit : fruits) {qDebug() << fruit;}
}
http://www.lryc.cn/news/2387779.html

相关文章:

  • Vue3监听对象数组属性变化方法
  • 深入了解PyTorch:起源、优势、发展与安装指南
  • DeepSeek智能对话助手项目
  • 浅谈Mysql的MVCC机制(RC与RR隔离级别)
  • uniapp-商城-72-shop(5-商品列表,购物车实现回顾)
  • 【git】 pull + rebase 或 pull + merge什么区别?
  • 1. 编程语言进化史与JavaScript
  • Vue3 中 Axios 深度整合指南:从基础到高级实践引言
  • MySQL#Select语句执行过程
  • hbuilder中h5转为小程序提交发布审核
  • 文档注释:删还是不删
  • 【数据结构】单链表练习
  • JVM 性能优化终极指南:全版本兼容、参数公式与场景实战
  • 分布式爬虫监控架构设计
  • MySQL的参数 innodb_force_recovery 详解
  • 学习vue3:跨组件通信(provide+inject)
  • Alibaba Sentinel 入门教程:从理论到实战
  • 2.3 TypeScript 非空断言操作符(后缀 !)详解
  • 【菜狗work前端】小程序加if判断时不及时刷新 vs Web
  • 01 NLP的发展历程和挑战
  • TCP 三次握手:详解与原理
  • LabVIEW累加器标签通道
  • 在 Unity 中,Start 方法直接设置 RectTransform 的位置,时出现问题,与预计位置不匹配。
  • 永磁同步电机控制算法--IP调节器
  • Ubuntu 25.04 锁屏不能远程连接的解决方案
  • Java 自动装箱和拆箱还有包装类的缓存问题
  • java-jdk8新特性Stream流
  • 大语言模型 21 - MCP 自动操作 Figma+Cursor 实现将原型转换为代码
  • QNAP NEXTCLOUD 域名访问
  • Spring MVC深度解析:控制器与视图解析及RESTful API设计最佳实践