QMap简单用法

QMap简单用法QMap提供了一个从类项为key的键到类项为T的直的映射,通常所存储的数据类型是一个键对应一个直,并且按照Key的次序存储数据,这个类也支持一键多值的情况,用类QMultiMapQHash具有和QMap几乎完全一样的APi,此类维护这一张哈希表,表的大小和数据项是自适应的,QHash是以任意的顺序住址他的数据,,当然了他也是可以支持一键多值的,QMultiHash两种之间的区别是:

大家好,又见面了,我是你们的朋友全栈君。

QMap提供了一个从类项为key的键到类项为T的直的映射,通常所存储的数据类型是一个键对应一个直,并且按照Key的次序存储数据,这个类也支持一键多值的情况,用类QMultiMap

QHash具有和QMap几乎完全一样的APi,此类维护这一张哈希表,表的大小和数据项是自适应的,QHash是以任意的顺序住址他的数据,,当然了他也是可以支持一键多值的,QMultiHash

两种之间的区别是:

QHash查找速度上显著于QMap

QHash以任意的方式进行存储,而QMap则是以key顺序进行存储.

Qhash 的键类型必须提供operator==()和yige 全局的qHash(key)函数。而QMap的键类型key必须提供operator<()函数.

他们同样也是有两种风格的迭代容器。用来进行遍历的。

///QMap<Key,T(value)> and QHash<K,T>#include <QtCore/QCoreApplication>#include <qmap.h>#include <qdebug.h>int main(int argc, char *argv[]){	QCoreApplication a(argc, argv);	QMap<QString,int> map;	map.insert("eins o",1);	map.insert("sieben",7);	map["a test"]=23;	//Normally, a QMap allows only one value per key. 	//If you call insert() with a key that already exists in the QMap, 	//the previous value will be erased	map["a test"]=13;	int val=map.value("a test");	qDebug()<<val;	int val2=map.value("error");	qDebug()<<val2;    ///0	int val3=map.value("error2",20);	qDebug()<<val3;	int val4=map.value("a test",40);	qDebug()<<val4;	using a java-style iterator	QMapIterator<QString,int> iter(map);	while(iter.hasNext())	{		iter.next();  ///放在前面		qDebug()<<iter.key()<<" "<<iter.value();	}	using an Stl-style iterator 	QMap<QString,int>::ConstIterator i=map.constBegin();	while(i!=map.constEnd())	{		qDebug()<<i.key()<<": "<<i.value();		++i;	}	QMap<QString,int>::Iterator it;	it=map.find("sieben");	if(it!=map.end())		it.value()=8;	for(QMap<QString,int>::ConstIterator ite=map.constBegin(); ite!=map.constEnd(); ++ite)		qDebug()<<ite.key()<<": "<<ite.value();	return 0;//a.exec();}

结果:

13
0
20
13
“a test”   13
“eins o”   1
“sieben”   7
“a test” :  13
“eins o” :  1
“sieben” :  7
“a test” :  13
“eins o” :  1
“sieben” :  8
请按任意键继续. . .

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/139038.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JavaScript 学习笔记——cssText

    JavaScript 学习笔记——cssText平常编写代码,更改一个元素样式的时候,自己都是用obj.style.width=”200px”;obj.style.position=”absolute”;obj.style.left=”100px”;之类的代码进行设置,这样的话如果更改样式很多的时候,就要写很多代码,难道不能像Jquery那样使用$(obj).css(……);这样进行设置么?于是自己搜了下使用Javascript批

    2022年7月14日
    16
  • 域名解析的DNS缓存如何清理

    域名解析的DNS缓存如何清理

    2021年11月4日
    43
  • kprobe分析内核kworker占用CPU 100%问题总结

    kprobe分析内核kworker占用CPU 100%问题总结kprobe分析内核kworker占用CPU100%问题总结CreatebyBillow.Jen,2020.3.8前言[引用]有的工程师在线上出问题的时候,非常慌乱,会去胡乱猜测可能的原因,但又缺乏任何证据去支持或者否证他的猜测与假设。他甚至会在线上反复地试错,反复地折腾,搞得一团乱麻,毫无头绪,让自己和身边的同事都很痛苦,白白浪费了宝贵的排错时间。但是当我们有了动态追踪技术之后,排…

    2022年9月24日
    2
  • san交换机保存配置_交换机是一种什么设备

    san交换机保存配置_交换机是一种什么设备场景:1、两台服务器ESXi1,ESXi22、两台SAN交换机FC1,FC23、4台SAN存储:store1and2,store3and4:其中1和2,3和4分别做了级联,12和34之间做了双活。网络拓扑如图FC交换机1–创建zonezonecreate”Stor1_A_H2_GSJ_ESXI1_P0″,”1,8;2,12″ :做端口绑定,将

    2025年8月6日
    1
  • 微软最牛MS08-067漏洞各系统补丁下载地址

    微软最牛MS08-067漏洞各系统补丁下载地址本次MS08-067严重漏洞各系统补丁地址例如以下:中文操作系统KB958644补丁下载地址:WindowsVista安全更新程序(KB958644)http://download.mic

    2022年7月3日
    27
  • 数据结构与算法学习笔记

    本文是王争老师的《算法与数据结构之美》的学习笔记,详细内容请看王争的专栏。有不懂的地方指出来,我做修改。数据结构与算法思维导图数据结构指的是“一组数据的存储结构”,算法指的是“操作数据的一组方法”。数据结构是为算法服务的,算法是要作用再特定的数据结构上的。最常用的数据结构预算法:数据结构:数组、链表、栈、队列、散列表、二叉树‘、堆、跳表、图、Tire树 算法:递归…

    2022年4月7日
    213

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号