应使用 begin() 和 end() 获取迭代器并配合 auto 推导类型,统一用 != 比较,删除元素时用 erase() 返回值更新迭代器,避免手动写具体迭代器类型或使用
用
begin()和end()获取迭代器,别直接写vector<int>::iterator</int>绝大多数容器遍历失败,是因为手动写了具体迭代器类型——比如硬写
vector<int>::iterator</int>或list<string>::const_iterator</string>。这不仅冗长,还容易在const容器或 auto 推导场景下编译报错。现代 C++ 的标准做法是统一用
begin()/end()成员函数(或非成员版本),让编译器自己推导类型:vector<int> v = {1, 2, 3}; for (auto it = v.begin(); it != v.end(); ++it) { cout << *it << " "; }
begin()返回指向首元素的迭代器,end()返回指向“末尾后一位置”的迭代器(不指向有效元素)- 对
const容器,begin()自动返回const_iterator,无需手动加cbegin()(除非你明确要禁止修改且兼容旧标准)- 用
auto是安全的:它会精确匹配容器实际返回的迭代器类型,包括vector的随机访问迭代器、list的双向迭代器等遍历时别用
!=判断结束,但对vector和deque可以“为什么我换了个容器就崩了?”——常见于把
vector代码原样搬到list或set上,还坚持用或 <code> 比较迭代器。只有随机访问迭代器(
vector、deque、array)才支持;而 <code>list、forward_list、set、map的迭代器只支持==和!=。立即学习“C++免费学习笔记(深入)”;
- 统一用
!=最安全:所有标准容器迭代器都支持- 千万别写
it —— 对 <code>list直接编译失败- 也别写
it :逻辑错误,<code>end()本就不该被解引用,且部分迭代器不支持删除元素时,
erase()返回新有效迭代器,别盲目++it这是最常踩的坑:边遍历边删,还按惯性写
++it,结果迭代器失效、跳过元素、甚至崩溃。
erase()在大多数容器(vector、list、map等)中会返回下一个有效的迭代器。正确做法是用返回值更新it:for (auto it = v.begin(); it != v.end(); ) { if (*it % 2 == 0) { it = v.erase(it); // 删除后 it 已指向下一元素 } else { ++it; } }
vector::erase()删除中间元素会移动后续元素,返回的迭代器是稳定的(指向原位置的下一个)list::erase()和map::erase()不涉及移动,返回的也是下一个节点的迭代器- 错误写法:
v.erase(it); ++it;——it已失效,再++是未定义行为用范围
for循环前,先想清楚要不要修改或删除范围
for(for (auto& x : container))写起来爽,但掩盖了迭代器细节。它适合只读或简单修改,不适合条件删除或需要跳过逻辑。
- 只读遍历:用
for (const auto& x : container),零开销,语义清晰- 需修改元素:用
for (auto& x : container),注意x是引用,改的就是原值- 要删除?别用范围
for—— 它内部隐藏了迭代器,无法控制erase()后的继续逻辑- 性能上没区别:范围
for底层就是展开成begin()/end()+ 迭代器循环,但可读性高,编译器优化也充分迭代器不是语法糖,是容器抽象的接口契约。搞清
begin()/end()的含义、erase()的返回值、不同容器迭代器的能力边界,比记住“怎么写循环”重要得多。
0
0
相关文章
C++怎么使用源码级调试_C++VS Code调试配置【开发】
C++怎么跨平台 C++编写跨平台代码注意事项【指南】
C++20中Concepts怎么定义_C++泛型编程模板约束使用教程【特性】
C++怎么使用source_location_C++调试信息教程【追踪】
C++如何利用std::condition_variable实现精准的线程同步?(并发原语)
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。
890
2023.08.02
const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。
557
2023.09.20
在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。
890
2023.08.02
int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。
594
2024.08.29
硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。
1708
2023.10.19
Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。
6
2026.02.28
热门下载
相关下载
最新文章





