operator-(std::reverse_iterator)

從 cppreference.com


 
 
迭代器庫
迭代器概念
迭代器原語
算法概念與工具
間接可調用概念
常用算法要求
(C++20)
(C++20)
(C++20)
工具
(C++20)
迭代器適配器
範圍訪問
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
 
在標頭 <iterator> 定義
template< class Iter1, class Iter2 >

typename reverse_iterator<Iter>::difference_type
    operator-( const reverse_iterator<Iter1>& lhs,

               const reverse_iterator<Iter2>& rhs );
(C++11 前)
template< class Iter1, class Iter2 >

auto operator-( const reverse_iterator<Iter1>& lhs,
                const reverse_iterator<Iter2>& rhs )

    -> decltype(rhs.base() - lhs.base());
(C++11 起)
(C++17 起為 constexpr)

返回兩個迭代器適配器間的距離。

目錄

[編輯] 參數

lhs, rhs - 要計算距離的迭代器適配器

[編輯] 返回值

rhs.base() - lhs.base()

[編輯] 註解

因為這是逆向迭代器,所以 operator- 返回的是 rhs.base() - lhs.base() 而不是 lhs.base() - rhs.base()

[編輯] 示例

#include <iostream>
#include <iterator>
#include <list>
#include <vector>
 
int main()
{
    std::vector vec{0, 1, 2, 3};
    std::reverse_iterator<std::vector<int>::iterator>
        vec_ri1{std::reverse_iterator{vec.rbegin()}},
        vec_ri2{std::reverse_iterator{vec.rend()}};
    std::cout << (vec_ri2 - vec_ri1) << ' '; // 4
    std::cout << (vec_ri1 - vec_ri2) << '\n'; // -4
 
    std::list lst{5, 6, 7, 8};
    std::reverse_iterator<std::list<int>::iterator>
        lst_ri1{std::reverse_iterator{lst.rbegin()}},
        lst_ri2{std::reverse_iterator{lst.rend()}};
//  auto n = (lst_ri1 - lst_ri2); // 错误:底层迭代器未实现随机访问迭代器
}

輸出:

4 -4

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 出版時的行為 正確行為
LWG 280 C++98 不允許異質相減 允許異質相減

[編輯] 參閱

推進或回退 reverse_iterator
(公開成員函數) [編輯]
令迭代器前進
(函數模板) [編輯]