QMap详解「建议收藏」

QMap详解「建议收藏」QMap详解QMap是Qt的一个模板类,它是基于红黑树算法的一套字典。QMap<Key,T>是Qt容器类型的一种,它通过(Key,value)存储一对值,并通过Key可以查找与之关联的value的值。QMap和QHash是很相似的,不同的地方是:QHash的查找速度比QMap要快很多。在对QHash进行迭代时,这些项是任意排序的。在QMap中,项总是按键排序。QHash的关键类型必须提供运算符==()和全局QHash(key)函数。QMap的关键类型必须提供操作符<(

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

QMap详解

QMap是Qt的一个模板类,它是基于红黑树算法的一套字典。

QMap<Key,T>是Qt容器类型的一种,它通过(Key, value)存储一对值,并通过Key可以查找与之关联的value的值。

QMap QHash是很相似的,不同的地方是:

  • QHash的查找速度比QMap要快很多。
  • 在对QHash进行迭代时,这些项是任意排序的。在QMap中,项总是按键排序。
  • QHash的关键类型必须提供运算符==()和全局QHash(key)函数。QMap的关键类型必须提供操作符<(),以指定全序顺序。从Qt 5.8.1开始,使用指针类型作为键也是安全的,即使底层操作符<()不提供全序关系。

这里有一个带有QString类型关键字和 int类型值的QMap示例:

 QMap<QString, int> map;

你可以用运算符[ ]插入一对 (key,value) 到QMap对象中:

 map["one"] = 1;
 map["three"] = 3;
 map["seven"] = 7;

除了使用运算符[ ]外,还可以使用函数insert() 插入

 map.insert("twelve", 12);

如果想要查询QMap对象中的值,使用运算符[ ] 或者函数 value()

 int num1 = map["thirteen"];
 int num2 = map.value("thirteen");

查看QMap对象中是否包含某一项,使用函数contains() //存在返回true,否则,返回false

 int timeout = 30;
 if (map.contains("TIMEOUT"))
     timeout = map.value("TIMEOUT");

假设QMap对象中 TIMEOUT 关键字不存在, value() 函数返回第二个参数:

 int timeout = map.value("TIMEOUT", 30);

通常,我们建议使用contains()和value()而不是操作符来查找QMap对象中的键。原因是,如果QMap对象中,不存在要查找的关键项,那么操作符会在QMap对象中自动地插入一个项。
例如。在这个例子中,将会创建1000个项在QMap对象中

 // WRONG
 QMap<int, QWidget *> map;
 ...
 for (int i = 0; i < 1000; ++i) { 
   
     if (map[i] == okButton)
         cout << "Found button at index " << i << endl;
 }

为了避免这个错误,应当用map.value(i) 代替 map[i]

要遍历QMap对象中的所有项,可以使用 迭代器(iterator).QMap提供了java风格的迭代器(QMapIterator和QMutableMapIterator)和STL样式的迭代器(QMap::const_iterator 和 QMap::iterator)。

如何使用java风格的迭代器

 QMapIterator<QString, int> i(map);
 while (i.hasNext()) { 
   
     i.next();
     cout << i.key() << ": " << i.value() << endl;
 }

如何使用STL样式的迭代器

 QMap<QString, int>::const_iterator i = map.constBegin();
 while (i != map.constEnd()) { 
   
     cout << i.key() << ": " << i.value() << endl;
     ++i;
 }

通常,QMap只允许每个键对应一个值。如果在QMap中有一个已经存在的键调用insert(),那么前面的值将被删除。例如:

map.insert("plenty",100);
map.insert("plenty",2000);
//"plenty"对应的值100,修改为2000

如果想让一个键对应多个值,可以通过调用函数insertMulti()实现(或者QMultiMap类实现).
检索一个键对应的所有值,使用函数values(const Key &key) ,这个函数返回一个QList类模板。

QList<int> values = map.values("plenty");
 for (int i = 0; i < values.size(); ++i)
     cout << values.at(i) << endl;

另一种方法是调用find()来获取第一个项的STL样式迭代器,并从获取的迭代器开始迭代。

QMap<QString, int>::iterator i  = map.find("plenty");
while( i != map.end() && i.key() == "plenty)
{ 
   
    cout << i.value() << endl;
    ++i
}

如果你只需要从QMap对象中查看值(不是键),可以使用foreach循环

 QMap<QString, int> map;
 ...
 foreach (int value, map)
     cout << value << endl;

插入的项也可以从QMap对象中删除。
第一种方法是:调用remove() //int QMap::remove(const Key &key) 函数,这将删除给定键的所有相关项。
第二种方法是:调用QMutableMapIterator::remove()。
第三种方法是:调用clear(),清空了QMap对象。

Map的键值和值数据类型必须是assignable data types。这种类型覆盖了你会遇见的所有类型。但是,例如,编译器不会让您将QWidget作为一个值存储; 相反,存储一个QWidget *。此外,QMap的键类型必须提供操作符<()。QMap使用它来保存它的条目,并假设如果两个键值x<y和y<x都不是true,那么x和y两个键都是相等的。

#ifndef EMPLOYEE_H
  #define EMPLOYEE_H

  class Employee
  { 
   
  public:
      Employee() { 
   }
      Employee(const QString &name, const QDate &dateOfBirth);
      ...

  private:
      QString myName;
      QDate myDateOfBirth;
  };

  inline bool operator<(const Employee &e1, const Employee &e2)
  { 
   
      if (e1.name() != e2.name())
          return e1.name() < e2.name();
      return e1.dateOfBirth() < e2.dateOfBirth();
  }


#endif // EMPLOYEE_H

在这个例子中,我们首先比较员工的名字。如果它们是相等的,我们就比较它们的出生日期.

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

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

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


相关推荐

  • 安卓手机如何打开.pdf(1)文件_手机pdf格式怎么使用查找功能

    安卓手机如何打开.pdf(1)文件_手机pdf格式怎么使用查找功能最近在做结算功能,需要上传发票功能,发票有电子和图片发票两种,技术这边有两种方案,一种是上传图片文件,还有一种是上传PDF格式发票文件,但是结算时财务说图片文件上面没有公司盖章,是无效的,于是把方案改为电子发票PDF和纸质发票,刚开始使用的文件管理器搜索手机内的PDF文件,在4.4系统上面打开文件管理器可以过滤掉非.pdf格式文件,在6.0及以上系统没有过滤掉,用的是intent打开u…

    2025年5月23日
    0
  • 中国银行笔试题目回忆录_中国银行好考吗

    中国银行笔试题目回忆录_中国银行好考吗亲,戳上面的蓝字关注我们哦!中国银行笔试回忆题目昨天刚考完的中国银行笔试题目,趁着头脑还比较清醒先在这里记录一下吧,我选的是中国银行的信息技术岗位。我是提前就进了考场,中国银行考场还是比较好的,还

    2022年8月3日
    12
  • SBC编码

    SBC编码SBC是一种低复杂度的编解码技术,压缩比率适中,支持16kHz,32kHz,44.1kHz和48kHz的采样率,也因此成为蓝牙高清语音的当然之选。对于16kHz的宽带语音而言,SBC能以64kbps数据速率对其进行4:1的压缩。但是,当SBC编码帧通过蓝牙传输时,它可能与底层蓝牙数据包不相匹配。因此,mSBC编解码技术被开发用于匹配SBC和蓝牙数据包,并于2011年5月被定义为Bluetoot

    2022年9月12日
    0
  • PCA算法过程_pca推导

    PCA算法过程_pca推导PCA是主成分分析(PrincipalComponentsAnalysis)的简称。这是一种数据降维技术,用于数据预处理。一般我们获取的原始数据维度都很高,那么我们可以运用PCA算法降低特征维度。这样不仅可以去除无用的噪声,还能减少很大的计算量。…

    2025年5月26日
    0
  • Laravel如何引用第三方(自定义)库

    Laravel如何引用第三方(自定义)库

    2021年10月25日
    35
  • 2018年系统架构设计师综合知识真题及详细答案解析

    2018年系统架构设计师综合知识真题及详细答案解析2018年系统架构师考试科目一:综合知识1.在磁盘调度管理中,应先进行移臂调度,再进行旋转调度。假设磁盘移动臂位于21号柱面上,进程的请求序列如下表所示。如果采用最短移臂调度算法,那么系统的响应序列应为()。  A.②⑧③④⑤①⑦⑥⑨  B.②③⑧④⑥⑨①⑤⑦  C.①②③④⑤⑥⑦⑧⑨  D.②⑧③⑤⑦①④⑥⑨【解析】  当进程请求读磁盘时,操作系统先进行…

    2022年5月6日
    60

发表回复

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

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