公共成员函数
<iterator>

std::reverse_iterator::operator+

reverse_iterator operator+ (difference_type n) const;
加法运算符
返回一个指向相对于当前迭代器指向元素位置向前n个位置的反向迭代器

该函数内部对基迭代器应用二元operator-,并返回一个用结果迭代器值构造的反向迭代器

请注意,此函数要求*基迭代器*是*随机访问迭代器*。

此运算符也重载为非成员函数,其左右操作数类型颠倒,但行为相同(参见operator+)。

参数

n
偏移的元素数量。
成员类型 difference_type基迭代器自身差值类型的别名。

返回值

指向第 n 个位置的迭代器。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
// reverse_iterator::operator+ example
#include <iostream>     // std::cout
#include <iterator>     // std::reverse_iterator
#include <vector>       // std::vector

int main () {
  std::vector<int> myvector;
  for (int i=0; i<10; i++) myvector.push_back(i);	// myvector: 0 1 2 3 4 5 6 7 8 9

  typedef std::vector<int>::iterator iter_type;

  std::reverse_iterator<iter_type> rev_it;

  rev_it = myvector.rbegin() +3;

  std::cout << "The fourth element from the end is: " << *rev_it << '\n';

  return 0;
}

输出

The fourth element from the end is: 6


数据竞争

该对象被访问。
返回的迭代器可用于访问或修改元素。

异常安全

提供与应用于*基迭代器*的操作相同的保证级别。

另见