最終更新日時(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もしくはequivalentであるかを調べる。
  • (2) : partial_orderingの値がpartial_ordering::greaterもしくはequivalentであるかを調べる。

戻り値

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
true
true
false

false
true
true
false

バージョン

言語

  • C++20

処理系

関連項目

参照