菜鸟教程 -- 学的不仅是技术,更是梦想!

C++ 教程
C++ 教程 C++ 简介 C++ 环境设置 C++ 基本语法 C++ 注释 C++ 数据类型 C++ 变量类型 C++ 变量作用域 C++ 常量 C++ 修饰符类型 C++ 存储类 C++ 运算符 C++ 循环 C++ 判断 C++ 函数 C++ 数字 C++ 数组 C++ 字符串 C++ 指针 C++ 引用 C++ 日期 & 时间 C++ 基本的输入输出 C++ 结构体(struct) C++ vector 容器 C++ 数据结构

C++ 面向对象

C++ 类 & 对象 C++ 继承 C++ 重载运算符和重载函数 C++ 多态 C++ 数据抽象 C++ 数据封装 C++ 接口(抽象类)

C++ 高级教程

C++ 文件和流 C++ 异常处理 C++ 动态内存 C++ 命名空间 C++ 模板 C++ 预处理器 C++ 信号处理 C++ 多线程 C++ Web 编程

C++ 资源库

C++ STL 教程 C++ 导入标准库 C++ 标准库 C++ 有用的资源 C++ 实例 C++ 测验 C++ <iostream> C++ <fstream> C++ <sstream> C++ <iomanip> C++ <array> C++ <vector> C++ <list> C++ <forward_list> C++ <deque> C++ <stack> C++ <queue> C++ <priority_queue> C++ <set> C++ <unordered_set> C++ <map> C++ <unordered_map> C++ <bitset> C++ <algorithm> C++ <iterator> C++ <functional> C++ <numeric> C++ <complex> C++ <valarray> C++ <cmath> C++ <string> C++ <regex> C++ <ctime> C++ <chrono> C++ <thread> C++ <mutex> C++ <condition_variable> C++ <future> C++ <atomic> C++ <type_traits> C++ <typeinfo> C++ <exception> C++ <stdexcept> C++ <cstdio> C++ <cstdint> C++ <memory> C++ <new> C++ <utility> C++ <random> C++ <locale> C++ <codecvt> C++ <cassert> C++ <cwchar> C++ <climits> C++ <cfloat> C++ <cstdlib> C++ <numbers> C++ OpenCV
(追記) (追記ここまで)

C++ 标准库 <iterator>

C++ 标准库中的 <iterator> 头文件提供了一组工具,用于遍历容器中的元素。迭代器是 C++ 标准模板库(STL)中的核心概念之一,它允许程序员以统一的方式访问容器中的元素,而不需要关心容器的具体实现细节。

迭代器是一个对象,它提供了一种方法来遍历容器中的元素。迭代器可以被视为指向容器中元素的指针,但它比指针更加灵活和强大。迭代器可以用于访问、修改容器中的元素,并且可以与 STL 算法一起使用。

迭代器主要分为以下几类:

  1. 输入迭代器(Input Iterator):只能进行单次读取操作,不能进行写入操作。
  2. 输出迭代器(Output Iterator):只能进行单次写入操作,不能进行读取操作。
  3. 正向迭代器(Forward Iterator):可以进行读取和写入操作,并且可以向前移动。
  4. 双向迭代器(Bidirectional Iterator):除了可以进行正向迭代器的所有操作外,还可以向后移动。
  5. 随机访问迭代器(Random Access Iterator):除了可以进行双向迭代器的所有操作外,还可以进行随机访问,例如通过下标访问元素。

常用函数(重点)

函数 作用 示例 说明
std::advance(it, n) 移动迭代器 n 步 advance(it, 2); 会修改原迭代器
std::distance(a, b) 计算两个迭代器距离 distance(v.begin(), v.end()); 返回元素个数
std::next(it, n) 返回向前 n 步的新迭代器 auto it2 = next(it, 2); 推荐,不修改原值
std::prev(it, n) 返回向后 n 步的新迭代器 auto it2 = prev(it, 1); C++11 起支持

迭代器适配器(非常重要)

迭代器适配器可以改变迭代器的行为,使其适配不同的使用场景。

适配器 作用 示例
std::back_inserter 尾部插入(调用 push_back) back_inserter(vec)
std::front_inserter 头部插入(调用 push_front) front_inserter(list)
std::inserter 指定位置插入 inserter(vec, it)

流迭代器(IO 简化神器)

类型 作用 示例
std::istream_iterator 从输入流读取数据 istream_iterator<int>(cin)
std::ostream_iterator 写入输出流 ostream_iterator<int>(cout, " ")

迭代器的语法

迭代器的语法通常如下:

#include &lt;iterator&gt;
// 使用迭代器遍历容器
for (ContainerType::iterator it = container.begin(); it != container.end(); ++it) {
 // 访问元素 *it
}

实例

下面是一个使用 <iterator> 头文件和迭代器遍历 std::vector 的示例:

实例

#include <iostream>
#include <vector>
#include <iterator>
#include <algorithm>

int main() {
// 创建一个 vector 容器并初始化
std::vector<int> vec = {1, 2, 3, 4, 5};

// 使用迭代器遍历 vector
for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) {
std::cout << *it << " ";
}
std::cout << std::endl;

// 使用 auto 关键字简化迭代器类型
for (auto it = vec.begin(); it != vec.end(); ++it) {
std::cout << *it << " ";
}
std::cout << std::endl;

// 使用 C++11 范围 for 循环
for (int elem : vec) {
std::cout << elem << " ";
}
std::cout << std::endl;

// 使用 back_inserter 自动插入
std::vector<int> v2;
std::fill_n(std::back_inserter(v2), 3, 100);

// 使用 ostream_iterator 输出
std::copy(v2.begin(), v2.end(),
std::ostream_iterator<int>(std::cout, " "));
std::cout << std::endl;

return 0;
}

输出结果:

1 2 3 4 5 
1 2 3 4 5 
1 2 3 4 5 
100 100 100 

总结

<iterator> 的核心作用可以总结为三点:

  • 统一访问方式:不同容器使用同一套遍历逻辑
  • 解耦容器与算法:算法只依赖迭代器
  • 提升代码复用性:同一段代码可适用于多种数据结构

对于初学者来说,建议优先掌握以下内容:

  • next / prev / distance
  • back_inserter
  • 迭代器遍历方式
AI 思考中...

点我分享笔记

  • 昵称 (必填)
  • 邮箱 (必填)
  • 引用地址

AltStyle によって変換されたページ (->オリジナル) /