第六章节 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");
相关推荐
c#上位机1 分钟前
C#异步编程之async、await
开发语言·c#
郑州光合科技余经理13 分钟前
实战分享:如何构建东南亚高并发跑腿配送系统
java·开发语言·javascript·spring cloud·uni-app·c#·php
爱装代码的小瓶子14 分钟前
【c++进阶】C++11新特性:一切皆可{}初始化
开发语言·c++·visual studio
yaoxin52112318 分钟前
273. Java Stream API - Stream 中的中间操作:Mapping 操作详解
java·开发语言·python
技术小甜甜18 分钟前
[Python实战] 告别浏览器驱动烦恼:用 Playwright 优雅实现网页自动化
开发语言·python·自动化
vortex519 分钟前
Bash 替换机制(一):命令替换与进程替换
开发语言·chrome·bash
小徐Chao努力25 分钟前
【GO】Gin 框架从入门到精通完整教程
开发语言·golang·gin
她说..26 分钟前
手机验证码功能实现(附带源码)
java·开发语言·spring boot·spring·java-ee·springboot
加成BUFF41 分钟前
C++入门讲解3:数组与指针全面详解
开发语言·c++·算法·指针·数组
GoWjw1 小时前
C语言高级特性
c语言·开发语言·算法