答案:迭代器是STL中访问容器元素的统一机制,通过begin()和end()获取指向首元素和末尾后位置的迭代器,使用递增操作遍历vector、list、map等容器,支持auto简化声明,实现安全高效的元素访问与操作。

在C++标准模板库(STL)中,iterator(迭代器)是访问容器元素的核心机制。它提供了一种统一的方式遍历不同类型的容器,如 vector、list、map 等,同时支持从简单遍历到复杂操作的多种高级技巧。
迭代器基础用法
每种STL容器都提供 begin() 和 end() 成员函数,分别返回指向第一个元素和“末尾之后”位置的迭代器。通过递增迭代器,可以逐个访问元素。
常见容器的迭代器使用方式如下:
- vector
v = {1, 2, 3};
for (auto it = v.begin(); it != v.end(); ++it) {
cout } - map
m = {{"a", 1}, {"b", 2}};
for (auto it = m.begin(); it != m.end(); ++it) {
cout first second }
使用 auto 关键字可简化声明,提升代码可读性。注意:end() 返回的是“尾后”位置,不能解引用。
立即学习“C++免费学习笔记(深入)”;
反向遍历与反向迭代器
STL 提供 rbegin() 和 rend() 来支持逆序遍历。它们返回反向迭代器,从最后一个元素开始向前移动。
示例:
for (auto rit = v.rbegin(); rit != v.rend(); ++rit) {
cout }
反向迭代器在需要逆序处理数据时非常有用,比如查找最后一个满足条件的元素,或输出栈式结构。
基于范围的for循环(C++11)
现代C++推荐使用基于范围的 for 循环,语法更简洁,不易出错:
for (const auto& item : container) {cout }
这种方式自动处理迭代器边界,适合大多数遍历场景。若需修改元素,使用非 const 引用;若只读,建议使用 const 引用避免拷贝。
高级遍历技巧
结合算法头文件(
-
find_if 与 lambda:在遍历中加入条件判断。
auto it = find_if(v.begin(), v.end(), [](int n) { return n % 2 == 0; });
if (it != v.end()) cout -
advance 与 distance:控制迭代器位置跳转。
auto it = v.begin();
advance(it, 2); // 向前移动2步
cout -
insert_iterator / back_inserter:在遍历中向目标容器插入数据。
copy(src.begin(), src.end(), back_inserter(dest));
这些技巧让遍历不再局限于“访问”,而是可组合、可扩展的操作流程。
基本上就这些。掌握迭代器的基本使用是基础,理解反向迭代和现代语法能提升效率,而结合算法库的高级技巧则让代码更灵活、更C++化。注意迭代器失效问题(如遍历时删除元素),不同容器规则不同,需特别留意。










