第六章节 Qt的关联与集合容器

目录

一、Qt关联容器介绍

二、QMap

三、QHash

四、QMultiMap

五、各个关联容器的比较

六、QSet

七、QMultiHash


一、Qt关联容器介绍

Qt 关联容器: QMap, QHash, QMultiMap,QMultiHash

Qt 集合容器:QSet

二、QMap

C++的 map,是关联容器,用来存储"键值对"。

QMap 和 std::map 类似。底层都是使用"平衡二叉树"(红黑树)来存储数据, 是有序关联 容器。

实例:

cpp 复制代码
QMap<QString, QString> addr;

//插入
addr.insert("Hakcer", "1111111111");
addr.insert("Hover", "2222222222");
addr.insert("Cacker", "3333333333");

//之前已经有"Hakcer"这个键了,此时直接把之前的值覆盖了
//QMap 的键不能相同
addr.insert("Hakcer", "0731-88888888");

//删除
addr.remove("Hakcer");

//是否包含指定的键
if(addr.contains("Hover")) 
{
    qDebug() << "Rose: " << addr["Rose"];
}

//返回所有的键值列表
QList<QString> keys = addr.keys();
addr.clear(); // 清空所有条目
int count = addr.size(); //返回所有的条目数

三、QHash

底层的数据结构是哈希表,是无序关联容器。

QHash 的接口几乎和 QMap 完全相同

实例

cpp 复制代码
QHash<QString, QString> addr;
//插入
addr.insert("Hacker", "1111111111");
addr.insert("Hover", "2222222222");
addr.insert("Caver", "3333333333");

//删除
addr.remove("Hacker");

//是否包含指定的键
if(addr.contains("Hover")) 
{
    qDebug() << "Hover: " << addr["Hover"];
}

//返回所有的键值列表
QList<QString> keys = addr.keys();
addr.clear(); // 清空所有条目
int count = addr.size(); //返回所有的条目数

四、QMultiMap

QMultimap 是 QMap 的子类。

区别在于,QMultiMap 可以存储具有相同键的项。 不

能使用 [ ] 来获取值(因为一个键,可能对应多个值)

cpp 复制代码
QMultiMap<QString, QString> addr;
//插入
addr.insert("Hacker", "1111111111");
addr.insert("Hover", "2222222222");
addr.insert("Caver", "3333333333");

//之前已经有"Hacker"这个键了,但是可以存储相同的键
//QMultiMap 的键可以相同
addr.insert("Hacker", "0731-88888888");

//修改
addr.find("Hover", "2222222222").value() = "9999999";

//查询
if(addr.contains("Hacker")) 
{
    //返回 QList<QString>
    qDebug() << "Hacker:" << addr.values("Hacker");
}

if (addr.contains("Hacker", "1111111111")) 
{
    //此时打印的可能是另一个值
    qDebug() << addr.value("Rock");
}

//删除"Hacker"对应的所有键值对
addr.remove("Hacker");

//删除 1 个键值对
addr.remove("Hover", "010-11223333")

五、各个关联容器的比较

Amort.O(1) : 如果调用其次,时间复杂度为 O(n); 如果调用多次,平均时间复杂度是 O(1)

六、QSet

QSet 用来存储唯一元素的集合。

在 QSet 的内部,是通过 QHash 来实现的

实例

cpp 复制代码
QSet<QString> addrs1;

addrs1.insert("长沙");
addrs1.insert("上海");
addrs1.insert("北京");

// addrs1.remove("北京");
// ... 很多接口和 QHash 相同

QSet<QString>addrs2;

addrs2 << "上海" << "北京" << "深圳" << "成都";

// 交集运算 从 addrs1 集合中,删除所有没有在 addrs2 的元素,并返回addrs 的引用
// 相当于: addrs1 = addrs1 交集 addrs2
addrs1.intersect(addrs2);
if (addrs1.intersects(addrs2)) 
{
    qDebug() << "addrs 和 addrs2 有共同元素";
}

//并集运算 相当于: addrs1 = addrs1 + addrs2
addrs1.unite(addrs2);

//差集运算
addrs1.subtract(addrs2);

//遍历
for(auto it = addrs1.constBegin(); it != addrs1.constEnd(); it++) 
{
    qDebug() << *it;
}

集合的运算规则:

时间复杂度:

七、QMultiHash

继承自 QHash 类, 可以实现多值映射,类似于 QMultiMap(用法也相似)

实例

cpp 复制代码
QMultiHash<QString, QString> addr;
//插入
addr.insert("Hacker", "1111111111");
addr.insert("Hover", "2222222222");
addr.insert("Caver", "3333333333");

//之前已经有"Hacker"这个键了,但是可以存储相同的键
//QMultiHash 的键可以相同
addr.insert("Hacker", "0731-88888888");

//修改
addr.find("Hover", "2222222222").value() = "9999999";

//查询
if(addr.contains("Hacker")) 
{
    //返回 QList<QString>
    qDebug() << "Hacker:" << addr.values("Hacker");
}

if (addr.contains("Hacker", "1111111111")) 
{
    //此时打印的可能是另一个值
    qDebug() << addr.value("Hacker");
}

//删除"Hacker"对应的所有键值对
addr.remove("Hacker");
//删除 1 个键值对
addr.remove("Hover", "2222222222");
相关推荐
Highcharts.js1 小时前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
测试员周周6 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
杜子不疼.8 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号38 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia9 小时前
Qt——编辑交互功能的实现
开发语言·qt
石山代码9 小时前
C++ 内存分区 堆区
java·开发语言·c++
无风听海10 小时前
C# 隐式转换深度解析
java·开发语言·c#
一只大袋鼠10 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
LuminousCPP11 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
web3.088899911 小时前
1688 图搜接口(item_search_img / 拍立淘) 接入方法
开发语言·python