在C++中,迭代器(Iterator)是一种用于遍历容器(如数组、向量、列表等)元素的对象
- 输入迭代器(Input Iterator):这是最基本的迭代器类型,只能用于从容器中读取元素。输入迭代器支持
++
(前置和后置)运算符进行迭代,以及*
运算符来访问当前元素。但是,输入迭代器不支持写操作,即不能通过迭代器修改容器中的元素。常见的输入迭代器包括istream_iterator
和istreambuf_iterator
。 - 输出迭代器(Output Iterator):与输入迭代器相反,输出迭代器只能用于向容器中写入元素。输出迭代器支持
++
(前置和后置)运算符进行迭代,以及*
运算符来访问当前位置。但是,输出迭代器不支持读操作,即不能通过迭代器访问容器中的元素。常见的输出迭代器包括ostream_iterator
和ostreambuf_iterator
。 - 前向迭代器(Forward Iterator):前向迭代器既可以用于读取元素,也可以用于写入元素。前向迭代器支持
++
(前置和后置)运算符进行迭代,以及*
运算符来访问当前元素。此外,前向迭代器还支持比较运算符==
和!=
,用于判断两个迭代器是否指向同一个元素。常见的前向迭代器包括forward_list
的迭代器。 - 双向迭代器(Bidirectional Iterator):双向迭代器既可以用于读取元素,也可以用于写入元素。双向迭代器支持
++
(前置和后置)运算符进行正向迭代,以及--
(前置和后置)运算符进行反向迭代。双向迭代器还支持*
运算符来访问当前元素,以及比较运算符==
和!=
。常见的双向迭代器包括set
、multiset
、map
和multimap
的迭代器。 - 随机访问迭代器(Random Access Iterator):随机访问迭代器是最强大的迭代器类型,它支持所有双向迭代器的功能,并且还支持随机访问。随机访问迭代器支持
+
、-
、+=
、-=
运算符进行跳跃式访问,以及[]
运算符进行下标访问。此外,随机访问迭代器还支持比较运算符<
、>
、<=
和>=
,用于比较两个迭代器之间的相对位置。常见的随机访问迭代器包括vector
、deque
、array
和string
的迭代器。
需要注意的是,不同类型的迭代器支持的操作是不同的,因此在使用迭代器时需要根据实际情况选择合适的迭代器类型。