QMap与QHash
关联容器可以保存任意多个具有相同类型的项,且它们由一个键索引。Qt提供两个主要的关联容器类:QMap<K, T>和QHash<K, T>。
QMap<K, T>是一个以升序键顺序存储键值对的数据结构。这种排列使它可以提供良好的查找插入性能及键序的迭代。在内部,QMap<K, T>是作为一个跳越列表(skip-list)来实现执行的。
在映射中插入项的一种简单方式是调用insert():
QMap<QString, int> map;
map.insert("eins", 1);
map.insert("sieben", 7);
map.insert("dreiundzwanzig", 23);
另外,也可以像下面一样,给一个指定的键赋值:
map["eins"] = 1;
map["sieben"] = 7;
map["dreiundzwanzig"] = 23;
[]操作符即可以用于插入也可以用于检索。如果在非常量映射中使用[]为一个不存在的键检索值,则会用给定的键和空值创建一个新的项。为了避免意外的创建空值,可以使用value()函数代替[]操作符来获得项。
int val = map.value("dreiundzwanzig")
如果键不存在,则利用值类型的默认构造函数,将返回一个默认值,同时不会创建新的项。对于基本类型和指针类型,将返回0值。我们可以指定另一默认值作为value()的第二个参数,例如:
int seconds = map.value("delay", 30);
这相当于:
int seconds = 30;
if (map.contains("delay");
seconds = map.value("delay");
QMap<K, T>的K和T数据类型可以是与int、double、指针类型、有默认构造函数的类、复制构造函数和赋值操作符相似的基本数据类型。此外,K类型必须提供operator<(),因为QMap<K, T>要使用这个操作符以提升键序顺序存储项。
QMap<K, T>的K和T有一对方便的函数keys()和values(),它们在处理小数据集时显的特别有用。它们分别返回映射键的QList和映射值的QList。
映射通常都是单一值的:如果赋予一个现有的键一个新值,则原有的旧值将被该新值取代,以确保两个项不会共有同一个键。通过使用insertMulti()函数或者QMlltiMap<K, T>方便的子类,可以让多个键值对有相同的键。QMap<K, T>重载了value(const K &), 返回一个给定键多有值的QList列表。例如:
QMultiMap<int, QString> multiMap;
multiMap.insert(1, "one");
multiMap.insert(1, "eins");
multiMap.insert(1, "uno");
QList<QString> vals = multiMap.values(1);
QHash<K, T>是一个在哈希表中存储键值对的数据结构。它的接口几乎与QMap<K, T>相同,但是与QMap<K, T>相比,它对K的模板类型有不同的要求,而且它提供了比QMap<K, T>更快的查找功能。
除了对存储在容器类中的所有值类型的一般要求,QHash<K, T>中K的值类型还需要提供一个operator==(),并需要一个能够为键返回哈希值的全局qHash()函数的支持。Qt已经为qHash()函数提供了对整型、指针型、QChar、QString以及QByteArray。
QHash<K, T>为它内部的哈希表自动分配最初的存储区域,并在有项被插入或者删除时重新划分所分配的存储区域的大小。也可以通过调用reserve()或者squeeze()来指定或者压缩希望存储到哈希表中的项的数目,以进行性能调整。通常的做法是利用我们预期的最大的项的数目来条用reserve(),然后插入数据,最后如果有多出的项,则调用squeeze()以使内存的使用减到最小。
虽然哈希表通常都是单一值的,但是使用insertMulti()函数或者MultiHash<K, T>方便的子类,也可以将多个值赋给同一个键。
除了QHash<K, T>之外,Qt还提供了一个用来高速缓存与键相关联的对象的QCache<K, T>类以及仅仅存储键的QSet<K>容器。在内部,它们都依赖于QHash<K, T>,且都像QHash<K, T>一样对K的类型有相同的要求。
最简便的遍历存储在关联容器中多有键值对的方式是使用Java风格的迭代器。因为迭代器必须能同时访问键和值,针对关联容器的Java风格的迭代器与连续容器的在运作方式有些差异。只要区别在于next()和previous()函数返回一个代表键值对的对象,而不是一个简单的值。我们可以使用key()和value()分别从这个对象中获得键和值。例如:
QMap<QString, int> map;
...
int sum = 0;
QMapIterator<QString, int> i(map);
while (i.hasNext())
sum += i.next().value();
如果需要同时存取键和值,可以先忽略next()或previous()的返回值并使用迭代器的key()和value()函数,它们都是针对最后被跳过的项进行操作的:
QMapIterator<QString, int> i(map);
while(i.hasNext()){
i.next();
if (i.value() > largestValue){
largestKey = i.key();
largestValue = i.value();
}
}
===========================================================================================
原文链接:http://newfaction.net/2010/11/17/qt-qhash-and-qmap-difference.html
QMap提供了一个从类项为key的键到类项为T的直的映射,通常所存储的数据类型是一个键对应一个直,并且按照Key的次序存储数据,
这个类也支持一键多值的情况,用类QMultiMap
QHash具有和QMap几乎完全一样的APi,此类维护这一张哈希表,表的大小和数据项是自适应的,QHash是以任意的顺序住址他的数据,,当然了他也是可以支持一键多值的,QMultiHash
两种之间的区别是:
QHash查找速度上显著于QMap
QHash以任意的方式进行存储,而QMap则是以key顺序进行存储
Qhash 的键类型必须提供operator==()和一个全局的qHash(key)函数。而QMap的键类型key必须提供operator<()函数
他们同样也是有两种风格的迭代容器。用来进行遍历的。。
STL 风格的
下面以一个例子来进行说明:
int main(int argc, char *argv[])
{
QMap<QString, QString> map;
map.insert("beijing", "111");
map.insert("shanghai", "021");
map.insert("tianjin", "022");
map.insert("chongqing", "023");
map.insert("jinan", "0531");
map.insert("wuhan", "027");
QMap<QString, QString>::const_iterator i;
for( i=map.constBegin(); i!=map.constEnd(); ++i)
qDebug() << i.key() <<" " << i.value();
QMap<QString, QString>::iterator mi;
mi = map.find("beijing");
if(mi != map.end())
mi.value() = "010";
QMap<QString, QString>::const_iterator modi;
qDebug() << "";
for( modi=map.constBegin(); modi!=map.constEnd(); ++modi)
qDebug() << modi.key() <<" " << modi.value();
return 0;
}
关联容器可以保存任意多个具有相同类型的项,且它们由一个键索引。Qt提供两个主要的关联容器类:QMap<K, T>和QHash<K, T>。
QMap<K, T>是一个以升序键顺序存储键值对的数据结构。这种排列使它可以提供良好的查找插入性能及键序的迭代。在内部,QMap<K, T>是作为一个跳越列表(skip-list)来实现执行的。
在映射中插入项的一种简单方式是调用insert():
QMap<QString, int> map;
map.insert("eins", 1);
map.insert("sieben", 7);
map.insert("dreiundzwanzig", 23);
另外,也可以像下面一样,给一个指定的键赋值:
map["eins"] = 1;
map["sieben"] = 7;
map["dreiundzwanzig"] = 23;
[]操作符即可以用于插入也可以用于检索。如果在非常量映射中使用[]为一个不存在的键检索值,则会用给定的键和空值创建一个新的项。为了避免意外的创建空值,可以使用value()函数代替[]操作符来获得项。
int val = map.value("dreiundzwanzig")
如果键不存在,则利用值类型的默认构造函数,将返回一个默认值,同时不会创建新的项。对于基本类型和指针类型,将返回0值。我们可以指定另一默认值作为value()的第二个参数,例如:
int seconds = map.value("delay", 30);
这相当于:
int seconds = 30;
if (map.contains("delay");
seconds = map.value("delay");
QMap<K, T>的K和T数据类型可以是与int、double、指针类型、有默认构造函数的类、复制构造函数和赋值操作符相似的基本数据类型。此外,K类型必须提供operator<(),因为QMap<K, T>要使用这个操作符以提升键序顺序存储项。
QMap<K, T>的K和T有一对方便的函数keys()和values(),它们在处理小数据集时显的特别有用。它们分别返回映射键的QList和映射值的QList。
映射通常都是单一值的:如果赋予一个现有的键一个新值,则原有的旧值将被该新值取代,以确保两个项不会共有同一个键。通过使用insertMulti()函数或者QMlltiMap<K, T>方便的子类,可以让多个键值对有相同的键。QMap<K, T>重载了value(const K &), 返回一个给定键多有值的QList列表。例如:
QMultiMap<int, QString> multiMap;
multiMap.insert(1, "one");
multiMap.insert(1, "eins");
multiMap.insert(1, "uno");
QList<QString> vals = multiMap.values(1);
QHash<K, T>是一个在哈希表中存储键值对的数据结构。它的接口几乎与QMap<K, T>相同,但是与QMap<K, T>相比,它对K的模板类型有不同的要求,而且它提供了比QMap<K, T>更快的查找功能。
除了对存储在容器类中的所有值类型的一般要求,QHash<K, T>中K的值类型还需要提供一个operator==(),并需要一个能够为键返回哈希值的全局qHash()函数的支持。Qt已经为qHash()函数提供了对整型、指针型、QChar、QString以及QByteArray。
QHash<K, T>为它内部的哈希表自动分配最初的存储区域,并在有项被插入或者删除时重新划分所分配的存储区域的大小。也可以通过调用reserve()或者squeeze()来指定或者压缩希望存储到哈希表中的项的数目,以进行性能调整。通常的做法是利用我们预期的最大的项的数目来条用reserve(),然后插入数据,最后如果有多出的项,则调用squeeze()以使内存的使用减到最小。
虽然哈希表通常都是单一值的,但是使用insertMulti()函数或者MultiHash<K, T>方便的子类,也可以将多个值赋给同一个键。
除了QHash<K, T>之外,Qt还提供了一个用来高速缓存与键相关联的对象的QCache<K, T>类以及仅仅存储键的QSet<K>容器。在内部,它们都依赖于QHash<K, T>,且都像QHash<K, T>一样对K的类型有相同的要求。
最简便的遍历存储在关联容器中多有键值对的方式是使用Java风格的迭代器。因为迭代器必须能同时访问键和值,针对关联容器的Java风格的迭代器与连续容器的在运作方式有些差异。只要区别在于next()和previous()函数返回一个代表键值对的对象,而不是一个简单的值。我们可以使用key()和value()分别从这个对象中获得键和值。例如:
QMap<QString, int> map;
...
int sum = 0;
QMapIterator<QString, int> i(map);
while (i.hasNext())
sum += i.next().value();
如果需要同时存取键和值,可以先忽略next()或previous()的返回值并使用迭代器的key()和value()函数,它们都是针对最后被跳过的项进行操作的:
QMapIterator<QString, int> i(map);
while(i.hasNext()){
i.next();
if (i.value() > largestValue){
largestKey = i.key();
largestValue = i.value();
}
}
===========================================================================================
原文链接:http://newfaction.net/2010/11/17/qt-qhash-and-qmap-difference.html
QMap提供了一个从类项为key的键到类项为T的直的映射,通常所存储的数据类型是一个键对应一个直,并且按照Key的次序存储数据,
这个类也支持一键多值的情况,用类QMultiMap
QHash具有和QMap几乎完全一样的APi,此类维护这一张哈希表,表的大小和数据项是自适应的,QHash是以任意的顺序住址他的数据,,当然了他也是可以支持一键多值的,QMultiHash
两种之间的区别是:
QHash查找速度上显著于QMap
QHash以任意的方式进行存储,而QMap则是以key顺序进行存储
Qhash 的键类型必须提供operator==()和一个全局的qHash(key)函数。而QMap的键类型key必须提供operator<()函数
他们同样也是有两种风格的迭代容器。用来进行遍历的。。
STL 风格的
下面以一个例子来进行说明:
int main(int argc, char *argv[])
{
QMap<QString, QString> map;
map.insert("beijing", "111");
map.insert("shanghai", "021");
map.insert("tianjin", "022");
map.insert("chongqing", "023");
map.insert("jinan", "0531");
map.insert("wuhan", "027");
QMap<QString, QString>::const_iterator i;
for( i=map.constBegin(); i!=map.constEnd(); ++i)
qDebug() << i.key() <<" " << i.value();
QMap<QString, QString>::iterator mi;
mi = map.find("beijing");
if(mi != map.end())
mi.value() = "010";
QMap<QString, QString>::const_iterator modi;
qDebug() << "";
for( modi=map.constBegin(); modi!=map.constEnd(); ++modi)
qDebug() << modi.key() <<" " << modi.value();
return 0;
}
转载于:https://www.cnblogs.com/senior-engineer/p/8287362.html
QMap与QHash相关推荐
- Qt中的QMap和QHash
文章目录 1 QMap深度解析 2 QHash深度解析 3 QMap和QHash对比分析 1 QMap深度解析 QMap是一个以升序键顺序存储键值对的数据结构: QMap原型为class QMap&l ...
- 深度解析QMap与QHash
一.QMap深度解析 1.QMap是一个以升序键顺序存储键值对的数据结构 (1)QMap原型为class QMap<K, T>模板 (2).QMap中的键值对根据key进行了排序 (3). ...
- 遍历qvector_Qt 中的数据结构类(2)QList、QLinkedList、QVector、 QMap、QHash
迭代器 QT支持两种类型的迭代器只读迭代器:const_iterator 读写迭代器:iterator 只读迭代器比读写迭代器操作速度快很多 一.QList 概念:是一个提供列表的模板类//函数: i ...
- QMap 和 QHash容器
QMap类. QHash类 QMap与QHash差别: ①QHash比QMap查找速度更快. ②QHash以任意顺序存储,QMap以Key顺序存储数据. ③QHash的Key必须提供operator= ...
- QList、QVector、QMap、QHash安全删除(指定删除、遍历删除、快速删除)
Q各种容易结构介绍: 除了QVarLengthArray,所有QTL数据都存放在堆空间,支持隐式共享. QVarLengthArray:数据存储在对象内,连续存储结构,无隐式共享功能: QVector ...
- Qt工作笔记-QHash与QMap查找速度粗略比较实战
因为工作需要,要大量用到查找,关于查找,在Qt中比较常用的就两个,一个QHash,一个QMap, 关于谁快,谁慢,官方已经给出了答案 但我们来实战下,因为时间复杂度的多少,在真实运行情况下有的时候,差 ...
- QHash 与 QMap的区别
QMap QMap是Qt的一个模板类,它是基于红黑树算的的一套字典,是Qt容器中的一种.它的原型是 QMap原型为class QMap <K,T>,它通过(Key.value)存储一对值, ...
- linux运行raxml,RAxML安装
1.下载解压 $ wget https://codeload.github.com/stamatak/standard-RAxML/zip/master -O standard-RAxML-maste ...
- Qt——容器类(译)
注:本文是我对Qt官方文档的翻译,错误之处还请指正. 原文链接:Container Classes 介绍 Qt库提供了一套通用的基于模板的容器类,可以用这些类存储指定类型的项.比如,你需要一个大小可变 ...
最新文章
- python实现syn半扫描_python 使用raw socket进行TCP SYN扫描实例
- php文件上传空间,PHP上传文件-PHP多文件上传
- YOLOv5的pytorch模型文件转换为ONNX文件
- 让微信扫描直接下载你的APK
- Java让数据库执行一条sql_java数据库编程——执行SQL 语句
- 一步步学习SPD2010--第九章节--使用可重用工作流和工作流表单
- labelme批量转换json
- bzoj2002:[Hnoi2010]Bounce 弹飞绵羊
- Java基础6:代码块与代码加载顺序
- SLIC超像素分割的算法介绍和源码分析(C++)
- Volley(六 )—— 从源码带看Volley的缓存机制
- 渴望成为架构师的你,或许需要与这些大咖来一场面基
- 浅谈select2的使用
- 电信光猫F652破解经验谈
- 关于概率论中常错的考点 左偏右偏
- PSM案例《价格敏感度分析》
- 记一次生产事故排查——CPU高负载原因排查分析
- 在bitlocker上锁的情况下,采用win10安装介质安装系统。
- c语言实现七巧板积木拼图大全,七巧板拼图积木的制作方法
- oracle重新编译package,oracle package 编译问题
热门文章
- linux文件管理器添加项目,LXQt 0.14 发布,文件管理器添加拆分视图
- 儿童手表怎么删除联系人_华为儿童手表4X体验:与你一起守护孩子的成长,带娃不再辛苦...
- 图像目标分割_1 概述
- 数据结构链表之单链表的快慢指针——3
- java拆分单元格_Java 拆分Excel单元格数据为多列
- cad怎么设置线的粗细_CAD软件中怎么设置CAD线宽?
- LeetCode 2032. 至少在两个数组中出现的值(哈希/位运算)
- python 清除字符串中的 emoji 表情
- LeetCode 664. 奇怪的打印机(区间DP)
- 04.卷积神经网络 W3.目标检测(作业:自动驾驶 - 汽车检测)