编程进阶网 编程进阶网
首页
  • 计算机原理
  • 操作系统
  • 网络协议
  • 数据库原理
  • 面向对象
  • 设计原则
  • 设计模式
  • 系统架构
  • 性能优化
  • 编程原理
  • 方案设计
  • 稳定可靠
  • 工程运维
  • 基础认知
  • 线性结构
  • 树与哈希
  • 工业级实现
  • 算法思想
  • 实战与综合
  • 算法题考核
  • C语言入门
  • C综合案例
  • C专栏博客
  • C标准集库
  • C++入门教程
  • C++综合案例
  • C++专栏博客
  • C++开发技巧
  • Java入门教程
  • Java综合案例
  • Java专栏博客
  • Go入门教程
  • Go综合案例
  • Go专栏博客
  • Go开发技巧
  • JavaScript入门
  • JavaScript高级
  • Android库解读
  • Android专栏
  • Android智能硬件
  • iOS ObjC入门
  • iOS Swift入门
  • iOS入门精通
  • Web之Html手册
  • Web之TypeScript
  • Web之Vue高级进阶
  • Linux之QML入门
  • Linux之QT核心库
  • Linux实践开发
  • Python教程
  • Shell&Bash教程
  • 工具脚本
  • 自动化脚本
  • 质量保障
  • 产品思考
  • 软实力
  • 开发流程
  • Git应用
  • 技术模版
  • 技术规范
  • Markdown
  • Mermaid
  • 开源协议
  • JSON工具
  • 文本工具
  • 图片处理
  • 文档转化
  • 代码压缩
  • 关于我
  • 自我精进
  • 职场管理
  • 职场面试
  • 心情杂货
  • 友情链接

杨充

专注编程 · 终身学习者
首页
  • 计算机原理
  • 操作系统
  • 网络协议
  • 数据库原理
  • 面向对象
  • 设计原则
  • 设计模式
  • 系统架构
  • 性能优化
  • 编程原理
  • 方案设计
  • 稳定可靠
  • 工程运维
  • 基础认知
  • 线性结构
  • 树与哈希
  • 工业级实现
  • 算法思想
  • 实战与综合
  • 算法题考核
  • C语言入门
  • C综合案例
  • C专栏博客
  • C标准集库
  • C++入门教程
  • C++综合案例
  • C++专栏博客
  • C++开发技巧
  • Java入门教程
  • Java综合案例
  • Java专栏博客
  • Go入门教程
  • Go综合案例
  • Go专栏博客
  • Go开发技巧
  • JavaScript入门
  • JavaScript高级
  • Android库解读
  • Android专栏
  • Android智能硬件
  • iOS ObjC入门
  • iOS Swift入门
  • iOS入门精通
  • Web之Html手册
  • Web之TypeScript
  • Web之Vue高级进阶
  • Linux之QML入门
  • Linux之QT核心库
  • Linux实践开发
  • Python教程
  • Shell&Bash教程
  • 工具脚本
  • 自动化脚本
  • 质量保障
  • 产品思考
  • 软实力
  • 开发流程
  • Git应用
  • 技术模版
  • 技术规范
  • Markdown
  • Mermaid
  • 开源协议
  • JSON工具
  • 文本工具
  • 图片处理
  • 文档转化
  • 代码压缩
  • 关于我
  • 自我精进
  • 职场管理
  • 职场面试
  • 心情杂货
  • 友情链接
  • README
  • Android提升进阶

  • iOS开发和进阶

  • Web开发和进阶

  • Linux应用开发

    • README
    • QML基础入门

    • QT核心库实践

      • README
      • 核心功能基础
      • 并发与多线程
      • 文件与IO系统
      • 日期与时间处理
      • 网络与序列化
      • QT事件系统
      • 信号与槽机制
      • 多媒体的应用
      • 容器类和算法
        • 9.1 容器类介绍
          • 9.1.1 序列容器
          • 9.1.2 关联容器
          • 9.1.3 字符串处理
        • 9.2 序列容器
          • 9.2.1 QList
          • 9.2.2 QVector
          • 9.2.3 QLinkedList
          • 9.2.4 QStack
          • 9.2.5 QQueue
      • 高级编程技巧
    • Linux实践开发

  • Apps
  • Linux应用开发
  • QT核心库实践
杨充
2025-08-21
目录

容器类和算法

# 09.容器类和算法

  • 9.1 容器类介绍
    • 9.1.1 序列容器
    • 9.1.2 关联容器
    • 9.1.3 字符串处理
  • 9.2 序列容器
    • 9.2.1 QList
    • 9.2.2 QVector
    • 9.2.3 QLinkedList
    • 9.2.4 QStack
    • 9.2.5 QQueue
  • 9.3 关联容器
  • 9.4 字符串处理

# 9.1 容器类介绍

# 9.1.1 序列容器

  • QList:通用动态数组
  • QVector:连续内存数组(Qt 6 中与 QList 合并)
  • QLinkedList:双向链表
  • QStack:栈实现
  • QQueue:队列实现

# 9.1.2 关联容器

  • QMap:红黑树实现的键值对
  • QHash:哈希表实现的键值对
  • QSet:无序集合
  • QMultiMap/QMultiHash:支持多值的映射

# 9.1.3 字符串处理

  • QString:Unicode 字符串处理
  • QByteArray:原始字节数据处理
  • QStringView:字符串视图(只读)
  • QChar:Unicode 字符处理

# 9.2 序列容器

# 9.2.1 QList

QList 是 Qt 中最常用的动态数组容器,支持快速随机访问和动态扩展。

#include <QList>
#include <QDebug>

int main() {
    QList<int> list;
    // 添加元素
    list << 1 << 2 << 3 << 4 << 5;
    // 访问元素
    qDebug() << "First element:" << list.first();
    qDebug() << "Last element:" << list.last();
    qDebug() << "Element at index 2:" << list.at(2);
    // 遍历元素
    for (int i = 0; i < list.size(); ++i) {
        qDebug() << "Element" << i << ":" << list[i];
    }
    // 删除元素
    list.removeAt(2);
    qDebug() << "After removal:" << list;

    return 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

性能特点

  • 支持快速随机访问(O(1))。
  • 插入和删除操作在中间较慢(O(n)),在末尾较快(O(1))。

# 9.2.2 QVector

在 Qt 6 中,QVector 和 QList 的实现已经合并,QVector 是 QList 的别名。

(1)基本用法

#include <QVector>
#include <QDebug>

int main() {
    QVector<int> vector;

    // 添加元素
    vector << 10 << 20 << 30 << 40 << 50;

    // 访问元素
    qDebug() << "First element:" << vector.first();
    qDebug() << "Last element:" << vector.last();
    qDebug() << "Element at index 2:" << vector.at(2);

    // 遍历元素
    for (int i = 0; i < vector.size(); ++i) {
        qDebug() << "Element" << i << ":" << vector[i];
    }

    // 删除元素
    vector.remove(2);
    qDebug() << "After removal:" << vector;

    return 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

(2)性能特点

  • 与 QList 相同,支持快速随机访问和动态扩展。

# 9.2.3 QLinkedList

QLinkedList 是一个双向链表容器,适合频繁插入和删除操作的场景。

(1)基本用法

#include <QLinkedList>
#include <QDebug>

int main() {
    QLinkedList<int> linkedList;
    // 添加元素
    linkedList << 100 << 200 << 300 << 400 << 500;
    // 访问元素
    qDebug() << "First element:" << linkedList.first();
    qDebug() << "Last element:" << linkedList.last();
    // 遍历元素
    for (auto it = linkedList.begin(); it != linkedList.end(); ++it) {
        qDebug() << "Element:" << *it;
    }
    // 删除元素
    linkedList.removeOne(300);
    qDebug() << "After removal:"; 
    for (int value : linkedList) {
        qDebug() << value;
    }
    return 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22

(2)性能特点

  • 插入和删除操作非常高效(O(1))。
  • 随机访问较慢(O(n))。

# 9.2.4 QStack

QStack 是一个后进先出(LIFO)的栈容器,基于 QList 实现。

(1)基本用法

#include <QStack>
#include <QDebug>

int main() {
    QStack<int> stack;
    // 压栈
    stack.push(1);
    stack.push(2);
    stack.push(3);
    // 访问栈顶元素
    qDebug() << "Top element:" << stack.top();
    // 弹栈
    while (!stack.isEmpty()) {
        qDebug() << "Popped:" << stack.pop();
    }
    return 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

(2)性能特点

  • 基于 QList,支持快速压栈和弹栈操作(O(1))。

# 9.2.5 QQueue

QQueue 是一个先进先出(FIFO)的队列容器,基于 QList 实现。

(1)基本用法

#include <QQueue>
#include <QDebug>

int main() {
    QQueue<int> queue;
    // 入队
    queue.enqueue(10);
    queue.enqueue(20);
    queue.enqueue(30);
    // 访问队首元素
    qDebug() << "Front element:" << queue.head();
    // 出队
    while (!queue.isEmpty()) {
        qDebug() << "Dequeued:" << queue.dequeue();
    }
    return 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

(2)性能特点

  • 基于 QList,支持快速入队和出队操作(O(1))。
上次更新: 2026/06/10, 11:13:41
多媒体的应用
高级编程技巧

← 多媒体的应用 高级编程技巧→

最近更新
01
信号崩溃快速排查
06-15
02
CoreDump破案
06-15
03
perf火焰图实战
06-15
更多文章>
Theme by Vdoing | Copyright © 2019-2026 杨充 | MIT License | 桂ICP备2024034950号 | 桂公网安备45142202000030
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式