Compares the contents of two array
s.
Let value_type
be the value type of array
(i.e., typename array::value_type):
1,2) Checks if the contents of lhs and rhs are equal, that is, they have the same number of elements and each element in lhs compares equal with the element in rhs at the same position.
Equivalent to:
return std::distance(lhs.begin(), lhs.end())
== std::distance(rhs.begin(), rhs.end())
&& std::equal(lhs.begin(), lhs.end(), rhs.begin());
return std::equal(lhs.begin(), lhs.end(), rhs.begin(), rhs.end());
(since C++14)3-7) Compares the contents of lhs and rhs lexicographically.
If any of the following conditions is satisfied, the behavior is undefined:
value_type
is not LessThanComparable.If any of the following conditions is satisfied, the behavior is undefined:
T
does not model three_way_comparable
.value_type
.The <
, <=
, >
, >=
, and !=
operators are synthesized from operator<=> and operator== respectively.
array
s whose contents to compare [edit] Return value Operator lhs and rhs
Linear in the size of the array
.
The relational operators are defined in terms of value_type
's operator<.
The relational operators are not defined. The rewritten candidate operator<=> will be selected by overload resolution.
operator<=> uses value_type
's operator<=> if possible, or value_type
's operator< otherwise. Notably, if the value_type
does not itself provide operator<=>, but is implicitly convertible to a three-way comparable type, that conversion will be used instead of operator<.
#include <cassert> #include <compare> #include <array> int main() { const std::array a{1, 2, 3}, b{1, 2, 3}, c{7, 8, 9}; assert ("" "Compare equal containers:" && (a != b) == false && (a == b) == true && (a < b) == false && (a <= b) == true && (a > b) == false && (a >= b) == true && (a <=> b) != std::weak_ordering::less && (a <=> b) != std::weak_ordering::greater && (a <=> b) == std::weak_ordering::equivalent && (a <=> b) >= 0 && (a <=> b) <= 0 && (a <=> b) == 0 && "Compare non equal containers:" && (a != c) == true && (a == c) == false && (a < c) == true && (a <= c) == true && (a > c) == false && (a >= c) == false && (a <=> c) == std::weak_ordering::less && (a <=> c) != std::weak_ordering::equivalent && (a <=> c) != std::weak_ordering::greater && (a <=> c) < 0 && (a <=> c) != 0 && (a <=> c) <= 0 && ""); }[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4