QMap

  • QMap原型为class QMap <K,T>,其中K表示键,T表示值,K和T属于映射关系.
  • QMap会根据K来自动进行升序键排序
  • QMap中的K类型必须重载operator < 

QMap常用函数如下:

const Key QMap::key ( const T & value );
//通过值来找键,若未找到则返回0,由于只对K键进行排序,所以该函数不是快速查找 const T QMap::value ( const Key & key );
//通过键来查找值, 若未找到则返回0,由于K键已进行排序,所以属于快速查找

QMap示例:

QMap<QString, int> map;          //定义键为QString型,值为int型

map["key 1"] = ;
map["key 1"] = ; //更新key 1的值
map["key 4"] = ;
map["key 2"] = ;
map.insert("key 3", ); //等价于: map["key 3"] = 3; QList<QString> list = map.keys(); for(int i=;i<list.length();i++)
{
qDebug()<< list[i]<<","<< map.value(list[i]) ;
}

打印:

"key 1" ,
"key 2" ,
"key 3" ,
"key 4" ,

也可以使用QMapIterator迭代器来遍历整个QMap

QMapIterator常用函数如下:

void toFront ();       //使迭代器的游标指向容器的头部

void toBack ();       //使迭代器的游标指向容器的尾部

Item next ();        //返回map中的下一项,并使迭代器的游标指向下一项

Item previous ();    //返回map中的上一项,并使迭代器的游标指向上一项

bool hasNext ();     //若迭代器的游标指向的map还有下一项,则返回true,,若为空则返回false

bool hasPrevious ();  //若迭代器的游标指向的map还有上一项,则返回true,,若为空则返回false

const Key &  key ();  //返回上一项的键(key)和数值(value);

const T& value();    //返回上一项的数值(value);

示例:

       QMap<QString, int> map;

        map["key 1"] = ;
map["key 1"] = ; //key 1将会覆盖之前的key 1
map["key 4"] = ;
map["key 2"] = ;
map.insert("key 3", ); QMapIterator<QString, int> it(map); while(it.hasNext())
{
it.next();
qDebug()<<it.key()<<","<<it.value();
}

在QMap类里也封装了一个  const_iterator 迭代类,也可以通过它来遍历整个QMap

示例如下:

QMap<QString, int> map;

map["key 1"] = ;
map["key 1"] = ; //key 1将会覆盖之前的key 1
map["key 4"] = ;
map["key 2"] = ;
map.insert("key 3", ); QMap<QString, int>::const_iterator it; for(it = map.begin();it!=map.end();it++)
{
qDebug()<< it.key()<<","<<it.value();
}

QHash

  • QHash原型为class QHash<K,T>,其中K表示键,T表示值,K和T属于映射关系.
  • 和QMap不同的是,QHash中的键值对不会进行自动排序,而是更据Hash值存储
  • QHash中的Key类型必须重载operator ==
  • QHash中的Key对象必须重载全局哈希函数qHash()
  • 由于QHash通过Hash表存储,所以查找比QMap快

QHash常用函数和QMap类似,示例如下:

QHash<QString, int> hash;

hash["key 1"] = ;
hash["key 1"] = ; //key 1将会覆盖之前的key 1
hash["key 4"] = ;
hash["key 2"] = ;
hash.insert("key 3", ); QList<QString> list = hash.keys(); for(int i=;i<list.length();i++)
qDebug()<<list[i]<<","<<hash.value(list[i]);

运行打印:

"key 1" ,
"key 2" ,
"key 3" ,
"key 4" ,

QHash的迭代器QHashIterator类用法,和QMap的使用方法一样.

QHash内部也封装了一个  const_iterator 迭代类,和QMap的使用方法也一样,比如:

        QHash<QString, int> hash;

        hash["key 1"] = ;
hash["key 1"] = ; //key 1将会覆盖之前的key 1
hash["key 4"] = ;
hash["key 2"] = ;
hash.insert("key 3", ); QHash<QString, int> ::const_iterator it; for(it=hash.begin();it!=hash.end();it++)
qDebug()<<it.key()<<","<<it.value();

QMap和QHash区别

最新文章

  1. es6转es5
  2. H5版俄罗斯方块(4)---火拼对战的雏形
  3. 炜煌T3POS58微打参数设置方法
  4. EL表达式 (详解)(转)
  5. import static与import的区别
  6. RabbitMQ学习(1):安装
  7. Python on Android
  8. Tinkphp定时发布文章的教程
  9. ZOJ-3410Layton&#39;s Escape(优先队列+贪心)
  10. Angular初级入门
  11. Pro Aspnet MVC 4读书笔记(3) - Essential Language Features
  12. redux深入理解之中间件(middleware)
  13. iOS监听模式系列之推送消息通知
  14. MySQL/MariaDB数据库忘掉密码解决办法--技术流ken
  15. ajax参数
  16. ajax跨域请求 Uncaught SyntaxError: Unexpected token :
  17. Apache SkyWalking的架构设计【译文】
  18. 201621123001 《Java程序设计》第8周学习总结
  19. (P2022 有趣的数)||(zoj Little Sub and Mr.Potato&#39;s Math Problem)(思维)
  20. java EE 环境配置(JDK + Tomcat + Eclipse for java EE)

热门文章

  1. Qt Creator快捷键设置
  2. Maven3-依赖
  3. VS Code 调试 Angular 和 TypeScript 的配置
  4. VSCode插件开发全攻略(十)打包、发布、升级
  5. 背水一战 Windows 10 (96) - 选取器: ContactPicker
  6. 爱上python之盲注探测脚本
  7. [Swift]在Swift项目中创建桥接头文件,Swift文件和Objective-C文件相互调用
  8. 软件测试人员需要掌握的linux命令(二)
  9. 网管到CEO的10年逆袭之路
  10. pm2日志管理pm2-logrotate介绍