operator==,!=,<,<=,>,>=,<=>(std::multimap)
| Defined in header  <map> | ||
| template< class Key, class T, class Compare, class Alloc > bool operator==( const std::multimap<Key, T, Compare, Alloc>& lhs, | (1) | |
| template< class Key, class T, class Compare, class Alloc > bool operator!=( const std::multimap<Key, T, Compare, Alloc>& lhs, | (2) | (until C++20) | 
| template< class Key, class T, class Compare, class Alloc > bool operator<( const std::multimap<Key, T, Compare, Alloc>& lhs, | (3) | (until C++20) | 
| template< class Key, class T, class Compare, class Alloc > bool operator<=( const std::multimap<Key, T, Compare, Alloc>& lhs, | (4) | (until C++20) | 
| template< class Key, class T, class Compare, class Alloc > bool operator>( const std::multimap<Key, T, Compare, Alloc>& lhs, | (5) | (until C++20) | 
| template< class Key, class T, class Compare, class Alloc > bool operator>=( const std::multimap<Key, T, Compare, Alloc>& lhs, | (6) | (until C++20) | 
| template< class Key, class T, class Compare, class Alloc > synth-three-way-result<T> | (7) | (since C++20) | 
Compares the contents of two multimaps.
multimap's ordering Compare.                                       rhs.begin(), rhs.end(), synth-three-way).This comparison ignores the multimap's ordering Compare.-  Tmodelsthree_way_comparable.
-  <is defined for values of type (possibly const-qualified)T, and<is a total ordering relationship.
| The  | (since C++20) | 
Parameters
| lhs, rhs | - | multimaps whose contents to compare | 
| - T, Keymust meet the requirements of EqualityComparable in order to use overloads (1,2). | ||
| - Keymust meet the requirements of LessThanComparable in order to use overloads (3-6). The ordering relation must establish total order. | ||
Return value
multimaps are equal, false otherwise.multimaps are not equal, false otherwise.Complexity
multimap.multimap.Notes
| The relational operators are defined in terms of the element type's operator<. | (until C++20) | 
| The relational operators are defined in terms of synth-three-way, which uses operator<=> if possible, or operator< otherwise. Notably, if the element does not itself provide operator<=>, but is implicitly convertible to a three-way comparable type, that conversion will be used instead of operator<. | (since C++20) | 
Example
#include <cassert> #include <compare> #include <map> int main() { std::multimap<int, char> a{{1, 'a'}, {2, 'b'}, {3, 'c'}}; std::multimap<int, char> b{{1, 'a'}, {2, 'b'}, {3, 'c'}}; std::multimap<int, char> c{{7, 'Z'}, {8, 'Y'}, {9, 'X'}, {10, 'W'}}; 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 && ""); }
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior | 
|---|---|---|---|
| LWG 3431 | C++20 | operator<=> did not require Tto model three_way_comparable | requires |