0

0

c++如何使用map容器_c++键值对存储操作方法【手册】

尼克

尼克

发布时间:2026-03-16 20:19:03

|

816人浏览过

|

来源于php中文网

原创

std::map insert() 静默失败因红黑树禁止重复 key,返回值 bool 标识成败;operator[] 查找不存在 key 会默认构造插入,应改用 find() 或 at();unordered_map 要求 hash 和 ==,map 只需 <;遍历时删除须用 erase() 返回的迭代器。

c++如何使用map容器_c++键值对存储操作方法【手册】

map 插入数据时为什么 key 重复就静默失败?

因为 std::mapinsert() 默认用的是 std::pair<const key t></const> 的语义,底层红黑树不允许重复 key —— 它不是“覆盖”,而是直接拒绝插入。你调了 insert(),返回值里那个 bool 就是成败标志,但很多人没检查。

常见错误现象:map.insert({k, v}) 看似执行了,但后续查不到新值,或者旧值还在;其实插入根本没成功。

  • 要用覆盖语义,改用 map[k] = v(会构造默认值再赋值,有开销)
  • 更推荐 map.emplace(k, v):如果 key 存在,不插入也不报错;返回 std::pair<iterator bool></iterator>bool 是是否插入成功
  • 想强制更新,直接 map[k] = v 最直白,但注意:若 T 没默认构造函数,operator[] 会编译失败

查找不存在的 key 时 operator[] 为什么会悄悄新建元素?

operator[] 的设计契约就是“访问并确保存在”——它会在 key 不存在时,用 T{} 构造一个默认值插入进去。这不是 bug,是标准行为,但极易引发逻辑错误。

使用场景:你只想读取,比如配置项查询、缓存命中判断,结果却意外污染了 map。

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

  • 只读查找一律用 map.find(k),返回 iterator,判 != map.end()
  • C++17 起可用 map.at(k),key 不存在抛 std::out_of_range,适合必须存在的场景
  • 别用 map[k] 做存在性判断,比如 if (map[k]) {...} —— 这已经改了 map

map 和 unordered_map 在 key 类型上有啥关键区别?

std::map 只要求 key 支持 operator<(或传自定义比较器),而 std::unordered_map 要求 key 有 std::hash<Key> 特化 + operator==

叮当好记-AI音视频转图文
叮当好记-AI音视频转图文

AI音视频转录与总结,内容学习效率 x10!

下载

容易踩的坑:自定义结构体当 key 时,map 只要写个 operator< 就能用;但 unordered_map 得额外提供哈希函数,否则编译报错:error: call to implicitly-deleted default constructor of 'std::hash<mystruct>'</mystruct>

  • 对简单类型(intstd::string),两者都开箱即用
  • 对自定义 struct,map 推荐写仿函数或 lambda 比较器,避免依赖全局 operator<
  • unordered_map 需显式特化 std::hash,或传第三个模板参数:哈希函数对象,比如 std::unordered_map<mystruct int myhash></mystruct>

遍历 map 时删元素为啥容易崩溃?

因为 std::map 迭代器失效规则和 vector 不同:删除某个节点,**仅使指向该节点的迭代器失效**,其他迭代器仍有效。但很多人写 for (auto it = m.begin(); it != m.end(); ++it) + m.erase(it),这时 it 已失效,++it 就 UB(通常 crash)。

正确做法只有一个:用 erase() 返回的下一个有效迭代器。

  • 删单个:用 it = m.erase(it),不要 ++it
  • 删满足条件的多个:用 while 循环 + erase() 返回值,例如 auto it = m.begin(); while (it != m.end()) { if (should_delete(*it)) it = m.erase(it); else ++it; }
  • C++20 起支持 erase_if(m, pred),更安全简洁

复杂点在于:map 的迭代器是双向的,不是随机访问,所以不能像 vector 那样先记下所有待删位置再批量删。每次删都得靠 erase 的返回值推进。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

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

1071

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

107

2023.09.25

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

513

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

384

2023.10.25

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

510

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

204

2025.07.04

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

510

2025.06.09

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

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

精品课程

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

共94课时 | 11.5万人学习

C 教程
C 教程

共75课时 | 5.5万人学习

C++教程
C++教程

共115课时 | 22.2万人学习

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

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