c++ - 使用迭代器获取 vector 的索引

标签 c++ indexing vector iterator

当迭代 vector 的元素时,最好使用迭代器而不是索引(参见 Why use iterators instead of array indices? )。

std::vector<T> vec;
std::vector<T>::iterator it;
for ( it = vec.begin(); it != vec.end(); ++it )
{
   // do work
}

但是,可能需要在循环体中使用索引。考虑到性能和灵 active /可扩展性,在这种情况下,以下哪项更可取?

  1. 回到索引循环
    std::vector vec;
    size_t i;
    for ( i = 0; i < vec.size(); ++i )
    {
       // use i
    }
    
  2. 计算偏移量
    std::vector vec;
    std::vector::iterator it;
    for ( it = vec.begin(); it != vec.end(); ++it )
    {
       size_t i = it - vec.begin(); 
       // use i
    }
    
  3. 使用 std::distance
    std::vector vec;
    std::vector::iterator it;
    for ( it = vec.begin(); it != vec.end(); ++it )
    {
       size_t i = std::distance( vec.begin(), it );
       // use i
    }
    

最佳答案

如果您计划只使用 vector ,您可能希望切换回索引循环,因为它比迭代器循环更清楚地传达您的意图。但是,如果您的程序在未来的发展可能会导致容器发生变化,您应该坚持使用迭代器并使用 std::distance,它保证适用于所有标准迭代器。

关于c++ - 使用迭代器获取 vector 的索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/132323/

相关文章:

r - 如何从满足给定条件的向量中随机删除一个元素?

c++ - 将 vector 放在数组元素中

c++ - 如何在C/C++中获取数组的距离

c++ - 如何在 qt 中为 QAbstractListModel 创建 CurrentIndexChanged 信号?

mongodb - 如何在 MongoDB 中创建嵌套索引?

用于特定查询的 MySQL 索引

mysql - 在 MySQL 中查找间隔行

java - 将另一个 vector 中包含的值添加到一个 vector 中...一个 vector 中的更改会反射(reflect)在另一个 vector 中吗?

c++ - 为什么 Visual Studio 2013 会发出 C4996 错误?

c++ - Qt QFrame成为独立窗口