- 浏览: 3451097 次
- 性别:
- 来自: 苏州
文章分类
最新评论
-
sonichy:
Qt5改动很多,要改改了。
基于QItemDelegate的例子1 SpinBoxDelegate -
我的主页6:
楼主,2.2子查询的分页方式:SELECT * FROM ar ...
Mysql 分页语句Limit用法 -
liguoqi:
非常感谢楼主的用心指导,工具以及图片例子都提供了 赞!
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载 -
liguoqi:
问下这个图片怎么解压损坏呀
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载 -
liguoqi:
楼主讲解的非常详细,还附带工具和图片例子,非常感谢
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载
转载:http://newfaction.net/2010/11/17/qt-qhash-and-qmap-difference.html
关联容器可以保存任意多个具有相同类型的项,且它们由一个键索引。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官网变更【2012】
2012-09-21 19:30 4226Qt最近被Digia完全收购,诺基亚这两年的不理不睬,没有魄力 ... -
【转】QT实现不规则窗体
2012-09-21 18:50 5021看到好文章,收藏一下: 看到网上有很多不规则窗体的实现 ... -
Qt应用程序如何使用DCMTK类库进行二次开发DICOM数据传输
2012-09-13 09:35 0参考文章: 1、Using DCMTK with ... -
【转】将QT开发的界面程序封装成DLL,在VC中成功调用
2012-09-11 10:33 21143最近手头的一个项目需要做一个QT界面,并且封装成DLL,然后 ... -
诺基亚挥别Qt,转手给Digia
2012-09-11 09:37 2870一家总部位于芬兰的IT业务供应商Digia今天宣布,已经签署了 ... -
Qt多线程间信号槽传递非QObject类型对象的参数
2012-09-07 15:29 21413一、以前就发现过这个问题: 在Qt项目中,有时候为了 ... -
QT样式表(QStyleSheet)
2012-08-17 10:37 17915QT样式表 (QStyleSheet) 作者:刘旭晖 ... -
FinalData磁盘文件恢复工具(绿色破解版)
2012-08-02 13:28 8625FinalData磁盘文件恢复工具(绿色破解版),使用起来很方 ... -
Eclipse Qt开发环境的建立【转】
2012-08-01 11:15 44071.下载Eclipse目前Eclipse+CDT已经可以 ... -
汽车辐射监测系统-Qt开发
2012-07-25 16:18 4705最近晚上抽空忙了两个月,才把一个小系统做完。虽然做的不是太完 ... -
Qt做发布版,解决声音和图片、中文字体乱码问题
2012-07-14 16:02 4881Qt做发布版,解决声音和图片、中文字体乱码问题 ... -
QTableView使用中的疑问,如何及时显示操作Model后的结果?
2012-06-01 14:52 0最终的解决方法:我正 ... -
【转】Qt QTableview使用
2012-06-01 09:49 9688QTableWidget是QT程序中常用的显示数 ... -
QTableView双击 单机事件信号
2012-06-01 09:47 23150双击QTableView的行,获取该行数据 代码 ... -
QMessageBox改变大小
2012-05-31 15:33 8475创建一个QMessageBox: QMessageBo ... -
更新QTableView中的进度条状态
2012-05-30 14:37 14898前段时间,我接触了,如何在一个QTableView中加入一个控 ... -
QThread 线程暂停 停止功能的实现
2012-05-29 11:56 12227为了实现Qt中线程的暂停运行,和停止运行的控制功能 需要在设 ... -
QT环境变量
2012-05-28 18:53 5601不知道为啥同事有台电脑,装完Qt-VS2008库,和VS Ad ... -
广告光
2012-05-24 18:33 0盈创广告联盟 http://www.yo114.cn/ ... -
Test
2012-05-24 18:22 2196Test<IMG SRC="cf08e32c2 ...
相关推荐
5.保证无毒 1.简单,方便,实用 3.实例可以自行改用 1.如有非法,本人无法律责任! 8.更多作品,查找标签“朱建强”7.... 4.如需联系我请看左边数字!1.如不知代表何物,那就放弃计算机吧! 0....CSDN老板不让我上传联系方式。
很多时候,我们使用双重map或者hash去处理缓冲区,但是key不够直观,本文,自定义key,解决多重map或者hash的key值问题。文中,使用Qmutimap进行测试,对mutilmap用法不熟悉的同学,可以学习一下,mutimap的用法。
QList用于链表,QMap和QHash则可以用于实现键值对映射,类似于树或图的节点和边的关系。这些容器类提供了丰富的操作方法,使得数据的增删改查变得简单易行。 在设计数据库接口时,QT提供了QSqlDatabase模块,可以...
5.保证无毒 1.简单,方便,实用 3.实例可以自行改用 1.如有非法,本人无法律责任! 8.更多作品,查找标签“朱建强”7.... 4.如需联系我请看左边数字!1.如不知代表何物,那就放弃计算机吧! 0....CSDN老板不让我上传联系方式。
接着,定义一个函数,接收配置文件路径和一组预定义的键名作为参数,返回一个映射结构,如QMap或QHash,来保存键值对: ```cpp QMap, QString> readConfig(const QString &filePath, const QStringList &keyList) ``...
此外,可能还会使用到QMap或QHash来存储和检索地理坐标信息。 GPRS短信程序(QTSMSApp)则涵盖了网络通信和短信服务。在嵌入式环境中,这通常需要使用Qt的QNetworkAccessManager和QNetworkReply类来实现HTTP请求和...
在"Qt诺基亚官方中文教程L3_Qt的数据类型机会及文件.ppt"中,你将学习到Qt如何处理各种数据类型,包括基本类型、容器类(如QList、QVector)和高级数据结构(如QMap、QHash)。此外,Qt还提供了强大的文件和I/O操作...
这些信息可以存储在QMap或QHash中,键为属性名,值为属性值。 4. **生成MIF文件**:MIF文件没有内置的Qt支持,所以你需要自己定义格式来写入文件。MIF文件由头部信息、几何数据和属性数据组成。你需要根据MIF格式...
- **容器类**:了解Qt提供的各种容器类,如顺序存储容器(QList, QQueue等)、关联存储容器(QMap, QHash等)及其遍历器和隐式数据共享机制。 - **Model-View架构**:这是一种设计模式,可以分离数据管理和视图展示,Qt...
- **关联存储容器**: 包括 QMap, QHash 等。 - **特点**: 基于键值对存储数据,提供高效的数据检索。 - **遍历器与隐式数据共享**: 提高容器类的使用效率和性能优化策略。 #### 七、Model-View架构 - **概念**: ...
在这个场景中,我们关注的是在C++ STL中的`map`容器中,使用字符串(`std::string`)作为键(key)与使用自定义结构体(struct)作为键在查找效率上的比较。`map`是一个关联容器,它提供了基于键的有序存储,通常...
在Qt框架中,我们通常会使用QMap、QHash等容器来存储键值对数据。这些容器已经提供了查找、插入、删除等操作,且支持迭代器,非常方便。然而,如果我们需要更高级的功能,或者特定的性能优化,可能会选择自定义数据...
- `QMap`和`QHash`是关联容器,用于存储键值对。`QMap`基于红黑树实现,保证了插入和查找的O(log n)效率,而`QHash`使用哈希表,提供了更快的平均查找速度。 - **QString**: `QString`是Qt中的字符串类,它提供...
这些容器包括QList、QVector、QStringList、QHash、QMap等。QList和QVector是基于动态数组的容器,适用于快速的随机访问和插入删除操作;QStringList则专门用于字符串操作;而QHash和QMap则是基于哈希表和红黑树的...
- **关联容器(QMap、QHash)** - 分别提供了基于键值对映射的容器。 - **泛型演算(Generic Algorithms)** - 提供了一系列通用算法,如排序、查找等。 **6.2 文件处理** - **QFile** - 用于文件操作的类,...
通过调⽤⽹络IP地址查询获取当前位置城市,调⽤和⻛天⽓城市搜索API获取该城市的ID,根据ID调⽤和⻛实时天⽓API获取该城市天⽓,使⽤QMap容器存储多⽇天⽓数据。程序中可搜索城市名或者点击定位按钮查询城市近期天⽓,...
- **关联存储容器**: 如QMap、QHash等容器的工作原理和应用场景。 - **遍历器**: 如何使用Qt容器类提供的迭代器进行高效的数据遍历。 - **隐式数据共享**: Qt容器类中如何实现内存的有效管理。 #### 14. Model-View...
- **QMap/QHash:** 键值对存储,前者提供有序存储。 14. **XML和JSON解析**: - **QDom/QXmlStreamReader/QJsonDocument/QJsonObject/QJsonArray:** 提供解析工具。 15. **QtQuick与Qt Widgets的性能考量与...