0

0

C++中map怎么遍历_C++标准库map容器迭代器使用方法【备忘】

冰火之心

冰火之心

发布时间:2026-02-09 16:27:45

|

207人浏览过

|

来源于php中文网

原创

C++11起推荐用范围for遍历map,简洁安全;需边遍历边删除时,必须用erase()返回值更新迭代器,避免迭代器失效。

c++中map怎么遍历_c++标准库map容器迭代器使用方法【备忘】

for 循环配合 autobegin()/end() 最常用

这是最直观、最不容易出错的遍历方式,C++11 起推荐写法。迭代器类型由 auto 自动推导,避免手写冗长的 std::map::iterator

注意:mapvalue_typestd::pair,所以键是 const,不能通过迭代器修改键值。

std::map m = {{1,"a"}, {2,"b"}, {3,"c"}};
for (auto it = m.begin(); it != m.end(); ++it) {
    std::cout << it->first << ": " << it->second << "\n";
}
// 或更简洁的范围 for(推荐)
for (const auto& pair : m) {
    std::cout << pair.first << ": " << pair.second << "\n";
}
  • const auto& 避免拷贝 std::pair,尤其当 V 是大对象时
  • 不要在循环中对 m 做插入/删除操作,会令迭代器失效(erase() 返回新有效迭代器,可安全使用)
  • 如果需要修改 value,用 auto&(不是 const auto&),但依然不能改 first

map 迭代器是双向迭代器,不支持 += 或随机访问

std::map 底层是红黑树,迭代器只支持 ++--==!=,不支持 it += 2it + 5 —— 这类操作会编译失败。

常见误用:

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

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载
// ❌ 编译错误:no match for ‘operator+=’
auto it = m.begin();
it += 3;

// ✅ 正确:只能逐个移动
std::advance(it, 3); // 需要 #include 
// 或手动三次 ++it
  • std::next(it, n)std::prev(it, n) 是安全替代,内部调用 std::advance
  • 想按索引访问第 N 个元素?map 没有 O(1) 索引访问能力,必须从头遍历或转成 vector(仅当需频繁随机访问时才考虑)

遍历时删除元素必须用 erase() 返回值更新迭代器

直接写 it++erase(it) 后继续循环,会导致迭代器悬空、未定义行为 —— 这是新手高频崩溃点。

// ❌ 危险!it 在 erase 后已失效,++it 是 UB
for (auto it = m.begin(); it != m.end(); ++it) {
    if (it->second == "to_delete") {
        m.erase(it); // it 失效了,但循环末尾还会 ++it
    }
}

// ✅ 正确:用 erase() 返回的下一个有效迭代器
for (auto it = m.begin(); it != m.end(); ) {
    if (it->second == "to_delete") {
        it = m.erase(it); // erase 返回下一个有效迭代器
    } else {
        ++it;
    }
}
  • map::erase(iterator) 在 C++11+ 返回 iterator,别再用旧式两步写法
  • 如果删多个满足条件的元素,这个模式是唯一安全通用解法
  • remove_if + erase 不适用于 map,因为没有 remove_if 的容器适配版本

遍历顺序就是 key 的升序,且稳定;但别依赖 pair 成员名以外的结构

map 保证按键严格升序遍历(std::less),每次运行结果一致。但要注意:it->firstit->second 是标准约定,不是结构体字段名。

以下写法虽能编译,但不可靠:

// ❌ 不推荐:依赖内存布局,且语义不清
std::cout << it->pair::first << "\n"; // 错误语法
std::cout << (&*it)->first << "\n"; // 无必要且易读性差
  • 始终用 it->first / it->second,这是标准保证的接口
  • 如果 key 类型自定义,确保其 operator 是严格弱序,否则遍历顺序未定义甚至导致迭代器卡死
  • 需要降序?用 std::map> 或反向迭代器 rbegin()/rend()
实际写的时候,多数情况用范围 for 就够了;真要边遍历边删,就老老实实用 erase() 返回值接住迭代器——这点漏掉,调试半小时都未必想到。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

209

2023.10.12

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

541

2023.09.20

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

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

302

2025.06.09

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

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

196

2025.07.04

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1344

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

298

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2201

2025.12.29

java接口相关教程
java接口相关教程

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

34

2026.01.19

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

127

2026.02.06

热门下载

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

精品课程

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

共94课时 | 8.9万人学习

C 教程
C 教程

共75课时 | 4.6万人学习

C++教程
C++教程

共115课时 | 16.7万人学习

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

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