operator==,!=,<,<=,>,>=(std::tuple)
Defined in header
<tuple>
|
||
template< class... TTypes, class... UTypes >
bool operator==( const tuple<TTypes...>& lhs, |
(1) | (since C++11) |
template< class... TTypes, class... UTypes >
bool operator!=( const tuple<TTypes...>& lhs, |
(2) | (since C++11) |
template< class... TTypes, class... UTypes >
bool operator<( const tuple<TTypes...>& lhs, |
(3) | (since C++11) |
template< class... TTypes, class... UTypes >
bool operator<=( const tuple<TTypes...>& lhs, |
(5) | (since C++11) |
template< class... TTypes, class... UTypes >
bool operator>( const tuple<TTypes...>& lhs, |
(4) | (since C++11) |
template< class... TTypes, class... UTypes >
bool operator>=( const tuple<TTypes...>& lhs, |
(6) | (since C++11) |
1-2) Compares every element of the tuple lhs
with the corresponding element of the tuple rhs
.
3-6) Compares lhs
and rhs
lexicographically, that is, compares the first elements, if they are equivalent, compares the second elements, if those are equivalent, compares the third elements, and so on.
All comparison operators are short-circuited; they do not access tuple elements beyond what is necessary to determine the result of the comparison.
Contents |
[edit] Parameters
lhs, rhs | - | tuples to compare |
[edit] Return value
1) true if std::get<i>(lhs) == std::get<i>(rhs) for all i in [0, sizeof...(Types))
, otherwise false. For two empty tuples returns true.
2) !(lhs == rhs)
3) (bool)(std::get<0>(lhs) < std::get<0>(rhs)) || (!(bool)(std::get<0>(rhs) < std::get<0>(lhs)) && lhstail < rhstail), where lhstail
is lhs without its first element, and rhstail
is rhs without its first element. For two empty tuples, returns false.
4) !(lhs < rhs)
5) rhs < lhs
6) !(rhs < lhs)
[edit] Example
Because operator< is defined for tuples, containers of tuples can be sorted.
#include <iostream> #include <tuple> #include <vector> #include <algorithm> int main() { std::vector<std::tuple<int, std::string, float>> v; v.emplace_back(2, "baz", -0.1); v.emplace_back(2, "bar", 3.14); v.emplace_back(1, "foo", 100.1); std::sort(v.begin(), v.end()); for(auto p: v) { std::cout << "(" << std::get<0>(p) << ", " << std::get<1>(p) << ", " << std::get<2>(p) << ")\n"; } }
Output:
(1, foo, 100.1) (2, bar, 3.14) (2, baz, -0.1)