Qt入门系列开发教程【STL篇】QMultiHash多值散列表
【摘要】
😈「作者主页 」:鱼酱2333 😈「 B站首页 」:鱼酱2333 😈「本文录入专栏」:Qt入门系列开发教程 😈「本文内容」:QMultiHash多值散列表使用方法
文章目录
1...
😈「作者主页 」:鱼酱2333
😈「 B站首页 」:鱼酱2333
😈「本文录入专栏」:Qt入门系列开发教程
😈「本文内容」:QMultiHash多值散列表使用方法
1.应用场景
字典场景,多个Key对应多个Value形式。
2.QMultiHash
简介
QMultiHash<Key, T> 是 Qt 的通用容器类之一。 它继承了 QHash 并通过一些便利函数对其进行了扩展,使其比 QHash 更适合存储多值散列。 多值散列是允许具有相同键的多个值的散列。
所有API如下
//返回一个迭代器,该迭代器指向带有键 key 和映射中值 value 的项目。
typename QMultiHash<Key, T>::const_iterator constFind(const Key &key, const T &value) const
//如果包含具有键 key 和 value 值的项目,则返回 true; 否则返回false。
bool contains(const Key &key, const T &value) const
//返回具有键 key 和 value 值的项目数。
int count(const Key &key, const T &value) const
//返回一个迭代器,该迭代器指向地图中具有键 key 和 value 值的项。
typename QMultiHash<Key, T>::iterator find(const Key &key, const T &value)
typename QMultiHash<Key, T>::const_iterator find(const Key &key, const T &value) const
//使用键 key 和 value 值插入一个新项目。
typename QMultiHash<Key, T>::iterator insert(const Key &key, const T &value)
typename QMultiHash<Key, T>::iterator insert(typename QMultiHash<Key, T>::const_iterator pos, const Key &key, const T &value)
//从映射中删除所有具有键 key 和 value 值的项目。 返回删除的项目数。
int remove(const Key &key, const T &value)
//使用键 key 和 value 值插入一个新项目。
//如果已经有一个带有键键的项目,则该项目的值将替换为值。
typename QMultiHash<Key, T>::iterator replace(const Key &key, const T &value)
//用这个map交换其他map。 此操作非常快且永不失败。
void swap(QMultiHash<Key, T> &other)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
3.Example
追加头文件
#include <QMultiHash>
- 1
QMultiHash添加
QMultiHash<QString, int> map1, map2, map3;
map1.insert("plenty", 100);
map1.insert("plenty", 2000);
// map1.size() == 2
map2.insert("plenty", 5000);
// map2.size() == 1
map3 = map1 + map2;
// map3.size() == 3
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
QMultiHash遍历与查找
QMultiHash<QString, int> m;
m.insert("aa",1);
m.insert("aa",2);
m.insert("bb",1);
m.insert("cc",1);
m.insert("cc",2);
QList<int> values = m.values("cc");
for (int i = 0; i < values.size(); ++i)
qDebug()<< values.at(i);
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
QMultiHash<QString, int> m;
m.insert("aa",1);
m.insert("aa",2);
m.insert("bb",1);
m.insert("cc",1);
m.insert("cc",2);
QMultiHash<QString, int>::iterator i = m.find("aa");
while (i != m.end() && i.key() == "aa") {
qDebug() << i.value();
++i;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
QMultiHash删除
QMultiHash<QString, int> m;
m.insert("aa",1);
m.insert("aa",2);
m.insert("bb",1);
m.insert("cc",1);
m.insert("cc",2);
auto it = m.begin();
m.erase(it);
qDebug()<<m;
//删
m.clear();
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
文章来源: yujiang.blog.csdn.net,作者:鱼酱2333,版权归原作者所有,如需转载,请联系作者。
原文链接:yujiang.blog.csdn.net/article/details/122435751
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)