最終更新日時(UTC):
が更新

履歴 編集

function
<compare>

std::partial_ordering::operator<(C++20)

friend constexpr bool operator<(partial_ordering v, /*unspecified*/) noexcept;   // (1)

friend constexpr bool operator<(/*unspecified*/, partial_ordering v) noexcept;   // (2)

概要

  • (1) : partial_orderingの値がpartial_ordering::lessであるかを調べる。
  • (2) : partial_orderingの値がpartial_ordering::greaterであるかを調べる。

戻り値

int型のメンバ変数valueに各有効値に対応する値、bool型メンバ変数is_orderedに順序付けされているかどうかを保持しているとして、以下と等価

  • (1) : return is_ordered && v.value < 0
  • (2) : return is_ordered && 0 < v.value

例外

投げない。

備考

それぞれunspecifiedとなっている片側の引数には0リテラルのみが使用できる。それ以外の物を渡した場合、動作は未定義。

#include <iostream>
#include <compare>

int main()
{
  std::partial_ordering comp1 = 1 <=> 2;
  std::partial_ordering comp2 = 1 <=> 1;
  std::partial_ordering comp3 = -0.0 <=> +0.0;

  constexpr auto qnan = std::numeric_limits<double>::quiet_NaN();
  std::partial_ordering comp4 = qnan <=> qnan;

  std::cout << std::boolalpha;

  // (1) 
  std::cout << (comp1 < 0) << std::endl;
  std::cout << (comp2 < 0) << std::endl;
  std::cout << (comp3 < 0) << std::endl;
  std::cout << (comp4 < 0) << std::endl;
  std::cout << "\n";

  // (2)
  std::cout << (0 < comp1) << std::endl;
  std::cout << (0 < comp2) << std::endl;
  std::cout << (0 < comp3) << std::endl;
  std::cout << (0 < comp4) << std::endl;
}

出力

true
false
false
false

false
false
false
false

バージョン

言語

  • C++20

処理系

関連項目

参照