5.5 Qt 数据结构比较

5.5 Qt 数据结构比较

在 Qt 框架中,各种容器类和数据结构提供了丰富的功能,满足不同的编程需求。以下是对前面介绍的所有数据结构进行的详细比较。


一、基本比较表

数据结构特点适用场景复杂度
QList动态数组,支持快速索引和遍历,插入删除效率中等小规模列表管理,顺序操作较多的场景插入/删除:(O(n)),访问:(O(1))
QVector动态数组,性能类似于 QList,自 Qt 6 开始与 QList 同义与 QList 相同插入/删除:(O(n)),访问:(O(1))
QMap有序键值对存储,基于平衡二叉树实现需要排序的键值对存储插入/删除/查找:(O(\log n))
QHash无序键值对存储,基于哈希表实现快速查找,无需排序的数据存储平均插入/删除/查找:(O(1)),最坏 (O(n))
QSet无序集合,不允许重复值,基于哈希表实现快速判断元素是否存在平均插入/查找:(O(1))
QMultiMap有序键值对存储,支持键重复键值对有重复需求且需要排序的场景插入/删除/查找:(O(\log n))
QStack栈,基于 QList 实现后进先出的数据处理场景压栈/弹栈:(O(1))
QQueue队列,基于 QList 实现先进先出的数据处理场景入队/出队:(O(1))

二、分类比较

按是否有序分类
  • 有序数据结构:QMap、QMultiMap

    • 适合需要按键值排序的场景,例如时间序列数据。
  • 无序数据结构:QHash、QSet

    • 适合快速查找或判断存在性的场景,例如缓存和唯一值集合。
按存储类型分类
  • 键值对存储:QMap、QHash、QMultiMap

    • 适合需要存储成对信息的场景,例如 ID 和属性。
  • 线性存储:QList、QVector、QStack、QQueue

    • 用于顺序操作或简单的线性数据管理。
  • 集合存储:QSet

    • 适用于唯一值的存储和快速查询。

三、性能分析

操作QList/QVectorQMapQHashQSetQStack/QQueue
插入/删除(O(n))(O(\log n))平均 (O(1))平均 (O(1))(O(1))
查找(O(n))(O(\log n))平均 (O(1))平均 (O(1))不支持查找
遍历(O(n))(O(n))(O(n))(O(n))(O(n))

四、选择建议

  1. 按顺序操作:
  • 数据需要排序时,选择 QMap 或 QMultiMap。

  • 如果操作简单,选择 QList 或 QVector。

  1. 按访问速度:
  • 快速查找选择 QHash 或 QSet。

  • 对栈或队列操作选择 QStack 或 QQueue。


总结以上比较,不同的 Qt 数据结构提供了多种功能和优化选项。选择适合的结构能够显著提升代码性能和可维护性。

不多说,本人不大懂C,不能说教程到底怎么样,听说挺好的,为网传资源,资源过大上传乃是下载链接,不多说,下面上目录,行不行您自个儿看着办: 1.01-1-Qt讲解及Qt开发工具(编辑环境)讲解 2.01-2-登录界面布局讲解 3.01-3-登录界面功能介绍讲解: H# E. \' |0 {5 T 4.01-4-手动编写登录界面实现讲解: t# m, S# u7 e" t K. ? 5.01-5-手动编译qt源代码过程讲解 `+ }3 y$ y* r 6.01-6-手动实现信号与槽的连接过程4 M. l0 {# Q6 I& B/ G0 i- M1 L1 c 7.01-7-计算器实现思路讲解 8.02-1- 计算器功能的实现4 M) ?/ t H2 }: W/ I. T2 ^ 9.02-2- 对Qlabel的使用(图片,动画演示) 10.02-3-对apropressbon的使用 11.02-4- 对文本输入框的使用: o5 w4 j8 k( T$ z 12.03-1-多个窗体切换行* D4 u1 C, y- z 13.03-2-用QTimer、Qlabel实现倒计时、动画播放+ B; L* k# v5 V6 a( i2 h- N) D 14.03-3-QmessageDialog、QcolorDialog# W+ I4 d4 G: `( I, k$ @4 _ 15.03-4-多个窗体切换(静态公共方法实现) 16.03-5-QFontDialog、QIapontDialog、Qpropr 17.04-1-QFileDialog、QFile、对文件操作 18.04-2-鼠标事件(单击、双击、移动) 19.04-3-绘图事件9 [' Z2 ^/ t# B" t6 V3 ] 20.04-4-绘图事件例子讲解; J! L7 z. I3 P 21.04-5-关闭事件、窗体大小改变事件) ~# |7 D3 S k' ]% l9 M' \ v 22.05-1-棋盘类背景绘制 23.05-2-棋盘类:画棋盘 24.05-3-棋盘类:画棋盘(2)9 [' z( T+ ]8 w# v 25.05-4-棋盘类:普通落子" U' K1 ~! W6 N; A8 P) J 26.05-5-棋盘:增加位点、增加界面 27.05-6-增加吃子规则 28.05-7-棋盘:实现人人对战 29.05-8-棋盘:实现人机对战( M7 U' T! ~4 b4 @8 q 30.06-1-记事本:界面设计 31.06-2-记事本:新建功能 32.06-3-记事本:打开功能0 `4 Y8 d9 u! `6 ?, e, r 33.06-4-记事本:保存、另存为、退出 34.06-5-编辑、帮助功能. x( I, m, H( k/ y9 S9 g 35.06-6-记事本:右键菜单功能 36.07-1-Qprocess开启新的进程 37.07-2-实现QTimer(用QThread) 38.07-3-窗体附属功能 39.07-4-播放器:界面设计, n: o. O, r2 A# r8 Z1 N1 D 40.07-5-播放器:播放功能, Z) i8 h9 S5 Z5 p! R* ^5 S) a: e 41.07-6-播放器:快进、后退、上一页、下一页、声音调节$ t% z" z y- z! ` 42.07-7-播放器:播放功能的完善7 I/ H* F! j/ e0 }4 f* q) D5 c 43.08-1-播放器:拖动播放0 ?0 u' w8 _3 x/ j) B 44.08-2-播放器:放大、缩小 45.08-3-播放器:键盘放大、缩小 46.08-4-文本框、按钮赋值& Q" x8 J/ G3 a# G/ ?$ B 47.08-5-QListwidpet值切换实现- B* \- l7 L6 Y K8 R 48.08-6-QListwidpet拖动改变值 49.09-1-dow方式对xml读、 50.09-2-dow方式对xml写9 E. Q5 j0 d2 j$ Q: K3 K0 `) Y6 F 51.09-3-stream方式对xml读* D/ S8 S% x; E' s% |. T/ ^ 52.09-4-stream方式对xml写 53.09-5-http请求实现$ Q: ?/ ~1 s- R 54.10-1-http请求获取文件 55.10-2-tcp服务器实现步骤(1) 56.10-3-tcp服务器实现步骤(2) 57.10-4-tcp客户端实现 58.10-5-tcp文件服务器实现 59.11-1- 60.11-2-: {, u9 U) u1 A! B/ B& D7 f 61.11-3-% p& {$ D" J) V# ?. N& `8 u5 o' s2 S" | 62.11-4- 63.12-1-黑白棋:服务器实现) o1 R4 }' k% C" P4 S) g 64.12-2-黑白棋:网络对战实现/ O3 }6 l0 S6 S% J2 |% ^/ [ 65.12-3-SQL对表操作 66.12-4-SQL对表数据操作. q: ]2 K& m9 e$ g S' y 67.12-5-SQL触发器 68.13-1-SQL综合使用(1) 69.13-2-SQL综合使用(2)& R" A5 B# X7 e' |# p+ b 70.13-3-SQL综合使用(3)* V/ M' C) ?: E 71.13-4-SQL综合使用(4) 72.13-5-表设计Qt界面(1) 73.13-6-表设计Qt界面(2) 74.13-7-Qt与SQLite数据库的操作 75.14-1-QTablemodel与SQLite关联. c7 s: Q" K) t+ r! V 76.14-2-SQLite操作:插入 77.14-3-SQLite操作:查询、执行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值