为什么使用rbegin()而不是end() - 1?

Vic*_*ell 10 c++ iterator stl vector reverse-iterator

我想知道使用rbegin()而不是end() - 1对STL容器有什么好处.

例如,为什么你会使用类似的东西:

vector<int> v;
v.push_back(999);
vector<int>::reverse_iterator r = v.rbegin();
vector<int>::iterator i = r.base();
Run Code Online (Sandbox Code Playgroud)

而不是:

vector<int> v;
v.push_back(999);
auto r = v.end() - 1;
Run Code Online (Sandbox Code Playgroud)

Pao*_*o M 19

rbegin()返回一个反向 的迭代器operator++; 也就是说,reverse_iterator你可以通过一个容器向后迭代.

例:

#include <vector>
#include <iostream>

int main()
{
    std::vector<int> v{0,1,2,3,4};
    for( auto i = v.rbegin(); i != v.rend(); ++i )
        std::cout << *i << '\n';
}
Run Code Online (Sandbox Code Playgroud)

此外,一些标准容器,如std::forward_list返回前进迭代器,所以你将无法做到l.end()-1.

最后,如果你必须将你的迭代器传递给某些算法,就像std::for_each预先假定使用它一样operator++,你就不得不使用a reverse_iterator.


Mar*_*som 14

如果容器为空,end() - 1则不会定义.

  • @VictorBrunell:是的,不是.前向迭代器和反向迭代器不兼容.你不能做`v.begin()== v.rbegin()`.但是你可以比较它们指向的元素,即`&*(v.begin())==&*(v.rbegin())`被定义,对于1元素向量将是真的. (4认同)