我经常发现自己需要遍历 STL vector 。在执行此操作时,我需要同时访问vector 元素及其索引

我以前这样做是:

typedef std::vector<Foo> FooVec;
typedef FooVec::iterator FooVecIter;

FooVec fooVec;
int index = 0;
for (FooVecIter i = fooVec.begin(); i != fooVec.end(); ++i, ++index)
{
    Foo& foo = *i;
    if (foo.somethingIsTrue()) // True for most elements
        std::cout << index << ": " << foo << std::endl;
}

发现 BOOST_FOREACH 后,我将其缩短为:
typedef std::vector<Foo> FooVec;

FooVec fooVec;
int index = -1;
BOOST_FOREACH( Foo& foo, fooVec )
{
    ++index;
    if (foo.somethingIsTrue()) // True for most elements
        std::cout << index << ": " << foo << std::endl;
}

当同时引用 vector 元素及其索引时,是否有更好或更优雅的方法可以遍历STL vector ?

我知道另一种选择:for (int i = 0; i < fooVec.size(); ++i)但是我一直在阅读关于迭代这样的STL容器不是一种好的做法。

最佳答案

for (size_t i = 0; i < vec.size(); i++)
    elem = vec[i];

vector 是C数组的薄包装;无论您使用迭代器还是索引,它都一样快。但是其他数据结构并不是那么宽容,例如std::list。

09-06 13:59