名前空間
変種
操作

operator==,!=,<,<=,>,>=,<=>(std::reverse_iterator)

From cppreference.com
 
 
イテレータライブラリ
イテレータのコンセプト
イテレータのプリミティブ
アルゴリズムのコンセプトとユーティリティ
間接呼び出し可能コンセプト
共通アルゴリズム要件
(C++20)
(C++20)
(C++20)
ユーティリティ
(C++20)
イテレータアダプタ
Rangeアクセス
(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 >

bool operator==( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(1) (C++17 以降 constexpr)
template< class Iter1, class Iter2 >

bool operator!=( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(2) (C++17 以降 constexpr)
template< class Iter1, class Iter2 >

bool operator< ( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(3) (C++17 以降 constexpr)
template< class Iter1, class Iter2 >

bool operator<=( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(4) (C++17 以降 constexpr)
template< class Iter1, class Iter2 >

bool operator> ( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(5) (C++17 以降 constexpr)
template< class Iter1, class Iter2 >

bool operator>=( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(6) (C++17 以降 constexpr)
template< class Iter1, std::three_way_comparable_with<Iter1> Iter2 >

constexpr std::compare_three_way_result_t<Iter1, Iter2>
    operator<=>( const std::reverse_iterator<Iter1>& lhs,

                 const std::reverse_iterator<Iter2>& rhs );
(7) (C++20以降)

lhs と rhs の基底イテレータを比較します。

  • 等価比較の結果は保持されます(すなわち、基底イテレータが等しい場合、リバースイテレータも等しくなります)。
  • 順序比較の結果は反転します(すなわち、基底イテレータが大きい場合、リバースイテレータは小さくなります)。
1) このオーバーロードは、lhs.base() == rhs.base() が well-formed で bool に変換可能な場合にのみ、オーバーロード解決に参加します。
2) このオーバーロードは、lhs.base() != rhs.base() が well-formed で bool に変換可能な場合にのみ、オーバーロード解決に参加します。
3) このオーバーロードは、lhs.base() > rhs.base() が well-formed で bool に変換可能な場合にのみ、オーバーロード解決に参加します。
4) このオーバーロードは、lhs.base() >= rhs.base() が well-formed で bool に変換可能な場合にのみ、オーバーロード解決に参加します。
5) このオーバーロードは、lhs.base() < rhs.base() が well-formed で bool に変換可能な場合にのみ、オーバーロード解決に参加します。
6) このオーバーロードは、lhs.base() <= rhs.base() が well-formed で bool に変換可能な場合にのみ、オーバーロード解決に参加します。
(C++20以降)


目次

[編集] Parameters

lhs, rhs - 比較するイテレータアダプタ

[編集] Return value

1) lhs.base() == rhs.base()
2) lhs.base() != rhs.base()
3) lhs.base() > rhs.base()
4) lhs.base() >= rhs.base()
5) lhs.base() < rhs.base()
6) lhs.base() <= rhs.base()
7) rhs.base() <=> lhs.base()

[編集] Notes

operator<=> は、これがリバースイテレータであるため、lhs.base() <=> rhs.base() ではなく、rhs.base() <=> lhs.base() を返します。

[編集] Example

#include <cassert>
#include <iterator>
 
int main()
{
    int a[]{0, 1, 2, 3};
    //            ↑  └───── x, y
    //            └──────── z
    // “x” and “y” are equal, but “x” is less than “z” (reversely)
    std::reverse_iterator<int*>
        x{std::rend(a) - std::size(a)},
        y{std::rend(a) - std::size(a)},
        z{std::rbegin(a) + 1};
 
    // two-way comparisons
    assert(  x == y );
    assert(!(x != y));
    assert(!(x <  y));
    assert(  x <= y );
    assert(!(x == z));
    assert(  x != z );
    assert(  x <  z );
    assert(  x <= z );
 
    // three-way comparisons
    assert(  x <=> y == 0 );
    assert(!(x <=> y <  0));
    assert(!(x <=> y >  0));
    assert(!(x <=> z == 0));
    assert(  x <=> z <  0 );
    assert(!(x <=> z >  0));
}

[編集] Defect reports

以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。

DR 適用対象 公開された動作 正しい動作
LWG 280 C++98 heterogeneous assignment was not allowed 許可
English 日本語 中文(简体) 中文(繁體)