【Test 55 】Qt 开发基础体系 QMap 类和 QHash 类以及 QVector 类

1.QMap 详解

1.1 QMap 的介绍

🐧① QMap<key,T>提供一个从类型为Key的键到类型为T的值的映射。通常,QMap存储的数据形式是一个键对应一个值,并且按照键Key的次序存储数据。

🐧② 为了能够支持一键多值的情况,QMap提供QMap<key,T>:insertMulti ()QMap<key,T>::values ()函数。QMultiMap 类来实例化一个QMap对象。



1.2 QMap 的具体用法如下

  • 🍎插入信息的方式:
    在这里插入图片描述


  • 🍎删除信息,直接通过 key 键删除
    在这里插入图片描述


  • 🍎遍历 QMap 类的两种迭代方式
    在这里插入图片描述


  • 🍎通过 key来找T,或者通过T来找key,注意在QMap中,可以通过值来找键的哦🐧
    在这里插入图片描述


  • 🍎对T值进行修改,直接采取insert()进行插入覆盖即可
    在这里插入图片描述


  • 🍎查询是否包含某个键
    在这里插入图片描述


  • 🍎分别输出所有的 keyT值,放到 QList中进行输出
    在这里插入图片描述


1.3 QmultiMap类

  • 例如一个学生有学号、姓名、性别、年龄,这个时候就要用到一个键对应多个值的概念啦!直接用QmultiMap类即可。

在这里插入图片描述



2.QHash 详解

🐧① QHash<Key,T>具有与QMap几乎完全相同的API。QHash 维护着一张哈希表(Hash Table),哈希表的大小与QHash的数据项的数目相适应。

🐧② QHash任意的顺序组织它的数据。当存储数据的顺序无关紧要时,
建议使用QHash作为存放数据的容器。



🍎①QHash 存储数据,注意数据存入的顺序是任意的❗
在这里插入图片描述



🍎②用迭代器进行遍历 QHash
在这里插入图片描述



3. QMap 和 QHash 的对比

🐧Ⅰ. QHash 与 QMap 的功能差不多,但 QHash 的查找速度更快;

🐧Ⅱ.QMap 是按照键的顺序存储数据,而 QHash 是任意顺序存储的;

🐧Ⅲ.QMap 的键必须提供"<”运算符,而 QHash 的键必须提供“=="运算符和
一个名为 qHash()的全局散列函数。



4. QVector 详解

QVector <T>相邻的内存当中存储给定数据类型T的一组数值。在一个QVector 的前部或者中间位置进行插入操作的速度是很慢的,这是因为这样的操作将导致内存中的大量数据被移动,这是由QVector 存储数据的方式决定的。



🍎①插入数据,有两种方式
在这里插入图片描述



🍎②求出 QVector中元素的个数,以及遍历所有元素
在这里插入图片描述



🍎③元素的删除,可以控制删除一个区间的元素哦(只需要给出起始位置和删除的个数即可)🔍
在这里插入图片描述



🍎④判断容器是否包含某个元素
在这里插入图片描述


在这里插入图片描述

  • 17
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

未来可期LJ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值