0

0

C++中std::multimap和map的区别?(支持存储具有相同键的元素)

尼克

尼克

发布时间:2026-01-22 11:27:10

|

824人浏览过

|

来源于php中文网

原创

std::multimap允许重复键而std::map不允许;前者insert总成功并返回iterator,后者insert返回pair表示是否插入成功;两者均基于红黑树,时间复杂度O(log n),遍历重复键须用equal_range而非find。

c++中std::multimap和map的区别?(支持存储具有相同键的元素)

std::multimap 允许重复键,std::map 不允许

这是最根本的区别std::map 要求每个 key 唯一,插入重复键时会忽略新元素或返回失败;而 std::multimap 明确设计为支持多个相同 keyvalue,所有插入都会成功(除非内存不足)。

常见错误现象:用 map[key] = value 尝试“追加”多个值,结果只有最后一个生效——因为 operator[]map 中会先默认构造一个值,再赋值,且不支持重复键。

  • std::mapinsert() 返回 std::pairbool 表示是否插入成功
  • std::multimapinsert() 总返回 iterator,不带成功标志
  • 两者都保持按键有序,底层都是红黑树,时间复杂度一致(O(log n) 插入/查找)

遍历相同键的所有元素要用 equal_range,不是 find

find()multimap 中只返回一个匹配迭代器(任意一个,不保证是第一个),无法获取全部。必须用 equal_range(key) 获取一对迭代器,表示该键对应的所有元素的左闭右开区间。

使用场景:比如记录日志按时间戳(int)分组,同一秒内多条日志,需要批量读取。

立即学习C++免费学习笔记(深入)”;

Kive
Kive

一站式AI图像生成和管理平台

下载
std::multimap logs;
logs.insert({1690000000, "login"});
logs.insert({1690000000, "fetch_data"});
logs.insert({1690000001, "logout"});

auto range = logs.equal_range(1690000000);
for (auto it = range.first; it != range.second; ++it) {
    std::cout << it->second << "\n"; // 输出 login 和 fetch_data
}

erase(key) 在 multimap 中删除全部匹配项,map 中只删一个(但 map 本来就没重复)

注意:std::map::erase(key) 删除的是键等于 key 的唯一节点;std::multimap::erase(key) 删除的是所有键等于 key 的节点。这个行为差异容易被忽略,尤其在写通用模板代码时。

  • 若只想删 multimap 中某一个匹配项,必须传入迭代器:erase(iterator)
  • erase(iterator) 在两者中行为一致:只删该位置元素
  • erase(first, last) 也一致:删区间内所有元素

性能与内存:multimap 略高开销,但通常可忽略

两者底层结构完全相同,只是 multimap 放宽了键唯一性约束。实际内存占用几乎无差别,插入/查找/删除的常数因子略高(因需处理等价键的边界比较),但对绝大多数应用没有可观测影响。

真正要注意的是语义误用:把 multimap 当成“自动去重的容器”用,或在本应要求键唯一的业务逻辑里误用 multimap,会导致后续逻辑出错——比如用 at(key)map 有,multimap 没有)时编译失败,或者遍历时漏掉部分数据。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

542

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

60

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

40

2025.11.27

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

38

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号