版权声明:若无来源注明,Techie亮博客文章均为原创。 转载请以链接形式标明本文标题和地址:
本文标题:QHash和QMultiHash使用     本文地址:http://techieliang.com/2017/12/557/

1. 介绍

QHash<Key, T>是一个在哈希表中存储键值对的数据结构。它的接口几乎与QMap<Key,
T>相同,但是与QMap<Key, T>相比,它对ey的模板类型有不同的要求,而且它提供了比QMap<Key,
T>更快的查找功能。

The key type of a QMap must provide operator<(). The
key type of a QHash must provide operator==() and a global hash function
called qHash() (see qHash).

QMap需要提供operator<()。QHash<K,
T>中K的值类型还需要提供一个operator==(),并需要一个能够为键返回哈希值的全局qHash()函数的支持。Qt已经为qHash()函数提供了对整型、指针型、QChar、QString以及QByteArray。

QMultiHash类似于QMultiMap相对于QMap的,实现了但key对应多值。

相关帮助文档:QHashQMultiHash

2. 简单范例

2.1. QHash

  1. #include <QHash>
  2. #include <QDebug>
  3. QHash<QString,int> m_map;
  4. m_map["a"] = 10;
  5. m_map["a"] = 11;
  6. m_map["as"] = 13;
  7. m_map.insert("b",22);//同key不同value
  8. m_map.insert("b",23);
  9. m_map.insert("ba",55);
  10. m_map.insert("ba",56);
  11. m_map.insert("t1",77);//同value不同key
  12. m_map.insert("t2",77);
  13. auto find_index = m_map.find("as");
  14. if(find_index!=m_map.end()) {
  15. qDebug()<<find_index.key()<<find_index.value();
  16. }
  17. qDebug()<<m_map.value("a");
  18. qDebug()<<m_map.value("b");
  19. qDebug()<<m_map.value("aa");
  20. qDebug()<<m_map.values("b");//测试同key不同value
  21. qDebug()<<m_map.key(22);
  22. qDebug()<<m_map.key(77);
  23. qDebug()<<m_map.keys(77);//测试同value不同key

结果

  1. "as" 13
  2. 11
  3. 23
  4. 0
  5. (23)
  6. ""
  7. "t2"
  8. ("t2", "t1")

2.2. QMultiHash

  1. QMultiHash<QString,int> m_map;
  2. //m_map["a"] = 10;
  3. //m_map["a"] = 11;
  4. //m_map["as"] = 13;
  5. m_map.insert("b",22);//同key不同value
  6. m_map.insert("b",23);
  7. m_map.insert("ba",55);
  8. m_map.insert("ba",56);
  9. m_map.insert("t1",77);//同value不同key
  10. m_map.insert("t2",77);
  11. auto find_index = m_map.find("as");
  12. if(find_index!=m_map.end()) {
  13. qDebug()<<find_index.key()<<find_index.value();
  14. }
  15. qDebug()<<m_map.value("a");
  16. qDebug()<<m_map.value("b");
  17. qDebug()<<m_map.value("aa");
  18. qDebug()<<m_map.values("b");//测试同key不同value
  19. qDebug()<<m_map.key(22);
  20. qDebug()<<m_map.key(77);
  21. qDebug()<<m_map.keys(77);//测试同value不同key
  22. //修改必须用replace
  23. m_map.replace("b",25);//讲第一个key=b的修改为了25
  24. m_map.replace("t3",77);//由于没有t3=77所以新增加了一个
  25. qDebug()<<m_map.values("b");
  26. qDebug()<<m_map.keys(77);

结果

  1. 0
  2. 23
  3. 0
  4. (23, 22)
  5. "b"
  6. "t1"
  7. ("t1", "t2")
  8. (25, 22)
  9. ("t1", "t2", "t3")

3. 自定义类型实现hash

QSet使用-自定义类型,QSet也是利用哈希表实现,原理相同。

转载请以链接形式标明本文标题和地址:Techie亮博客 » QHash和QMultiHash使用

QHash和QMultiHash使用的更多相关文章

  1. C++中的容器类详解

    一.STL容器类 STL(Standard Template Library)的六大组件:容器(containers).迭代器(iterators).空间配置器(allocator).配接器(adap ...

  2. Qt 学习之路:存储容器

    存储容器(containers)有时候也被称为集合(collections),是能够在内存中存储其它特定类型的对象,通常是一些常用的数据结构,一般是通用模板类的形式.C++ 提供了一套完整的解决方案, ...

  3. Qt 中一些常用类中文说明

    Qt 中一些常用类中文说明是本文讲述的内容,这篇文章主要是介绍Qt 当中经常使用的类,采取的是使用字母索引的方式,下面的类是被经常使用的. QDataStream 为QIODevice提供了一串的二进 ...

  4. Qt——容器类(译)

    注:本文是我对Qt官方文档的翻译,错误之处还请指正. 原文链接:Container Classes 介绍 Qt库提供了一套通用的基于模板的容器类,可以用这些类存储指定类型的项.比如,你需要一个大小可变 ...

  5. Qt 学习之路 2(38):存储容器

    Qt 学习之路 2(38):存储容器 豆子 2013年1月14日 Qt 学习之路 2 38条评论 存储容器(containers)有时候也被称为集合(collections),是能够在内存中存储其它特 ...

  6. Qt容器类之一:Qt的容器类介绍

    一.介绍 Qt库提供了一套通用的基于模板的容器类,可以用这些类存储指定类型的项.比如,你需要一个大小可变的QString的数组,则使用QVector<QString>. 这些容器类比STL ...

  7. QT5:先导篇 数据类型

    一.简介 二.字符串类(QString) 三.日期类(QData) 四.时间类(QTime) 五.顺序容器类 Qt的顺序容器类有QList QLinkedList  QVector QStack QQ ...

  8. Qt中的常用容器类(解释比较全面,有插图)

    在Qt库中为我们提供了一系列的基于模板的容器类.这些类可以被用来存储特定类型的项.例如,如果你需要一个大小可以变得QString数组,那么可以使用QVector<QString>. 这些容 ...

  9. Qt类库介绍

    QT类库 QT核心特点 QT是一个跨平台开发的类库. QT的元对象编译器MOC是一个预处理器,在源程序被编译前先将这些QT特性的程序转为标准的C++兼容的形式,然后再有标准的C++编译器进行编译.也就 ...

随机推荐

  1. SQL学习笔记:高级教程

    SQL语法 LIMIT select col from table limit number select * from table limit number LIKE select * from t ...

  2. 20155308&20155316 2017-2018-1 《信息安全系统设计基础》实验三

    20155308&20155316 2017-2018-1 <信息安全系统设计基础>实验三 并发程序-1 学习使用Linux命令wc(1) 基于Linux Socket程序设计实现 ...

  3. sort与qsort的异同

    主要内容: 1.qsort的用法 2.sort的用法 3.qsort和sort的区别 qsort的用法: 原 型: void qsort(void *base, int nelem, int widt ...

  4. php 换行 PHP_EOL

    在unix世界换行就用/n来代替,但是windows为了体现他的不同,就用/r/n,更有意思的是在mac中用/r.因此unix系列用 /n,windows系列用 /r/n,mac用 /r,这样就用你写 ...

  5. Dlib简介及在windows7 vs2013编译过程

    Dlib是一个C++库,包含了许多机器学习算法.它是跨平台的,可以应用在Windows.Linux.Mac.embedded devices.mobile phones等.它的License是Boos ...

  6. 【LG4309】【BZOJ3173】[TJOI2013]最长上升子序列

    [LG4309][BZOJ3173][TJOI2013]最长上升子序列 题面 洛谷 BZOJ 题解 插入操作显然用平衡树就行了 然后因为后面的插入对前面的操作无影响 就直接在插入完的序列上用树状数组求 ...

  7. SQL查找重复项目

    1 2 3 4 5 6 7 SELECT t1.* FROM t1,   (SELECT name,ADD    FROM t1    GROUP BY name,ADD HAVING COUNT(1 ...

  8. jsp 修改页面感受

    什么事情只有做过才知道. 最近在负责官网的开发,有一些页面需要和前端商量着修改,但是看到jsp那繁杂的标签和各种css,js混到一起,实在觉得jsp已经是一种落后的技术了,在修改过程中频频出现各种格式 ...

  9. Vue-lazyload 的使用

    Vue 项目使用 Vue-lazyload 做图片懒加载. 下载 下载 Vue-lazyload 的包NPM包 npm install vue-lazyload --save 引入 在项目 main. ...

  10. MySQL双主复制

    原文发表于cu:2017-06-12 本文简单介绍MySQL双主复制原理及1个简单是双主复制验证. 一.MySQL双主复制原理 1. 双主复制原理 master-master复制的两台服务器,既是ma ...