要向后迭代,请参阅此答案。
向前迭代几乎是相同的。只需按增量更改迭代器/交换减量。您应该更喜欢迭代器。有人告诉你使用std::size_t
作为索引的变量类型。但是,这不是便携式的。始终使用size_type
容器的 typedef(虽然您可以在前向迭代情况下只进行转换,但在使用 时,它实际上可能在反向迭代情况下一直出错std::size_t
,以防万一std::size_t
比 typedef 的类型更宽size_type
) :
使用 std::vector
使用迭代器
for(std::vector<T>::iterator it = v.begin(); it != v.end(); ++it) {
/* std::cout << *it; ... */
}
重要的是,对于您不知道其定义的迭代器,始终使用前缀增量形式。这将确保您的代码尽可能通用。
使用范围 C++11
for(auto const& value: a) {
/* std::cout << value; ... */
使用索引
for(std::vector<int>::size_type i = 0; i != v.size(); i++) {
/* std::cout << v[i]; ... */
}
使用数组
使用迭代器
for(element_type* it = a; it != (a + (sizeof a / sizeof *a)); it++) {
/* std::cout << *it; ... */
}
使用范围 C++11
for(auto const& value: a) {
/* std::cout << value; ... */
使用索引
for(std::size_t i = 0; i != (sizeof a / sizeof *a); i++) {
/* std::cout << a[i]; ... */
}
不过,请阅读向后迭代的答案,该sizeof
方法可以解决什么问题。