Difference between revisions of "cpp/coroutine/coroutine handle/operator cmp"
From cppreference.com
< cpp | coroutine | coroutine handle
m (fmt) |
Andreas Krug (Talk | contribs) m ({{c}}) |
||
Line 13: | Line 13: | ||
{{dcl end}} | {{dcl end}} | ||
− | Compares two {{c|std::coroutine_handle<>}} values {{ | + | Compares two {{c|std::coroutine_handle<>}} values {{|x}} and {{|y}} according to their underlying addresses. |
{{cpp/note synthesized compare}} | {{cpp/note synthesized compare}} | ||
Line 23: | Line 23: | ||
===Return value=== | ===Return value=== | ||
− | @1@ {{c|1=x.address() == y.address()}} | + | @1@ {{c|1=x.address() == y.address()}} |
− | @2@ {{c|std::compare_three_way{}(x.address(), y.address())}} | + | @2@ {{c|std::compare_three_way{}(x.address(), y.address())}} |
===Notes=== | ===Notes=== |
Latest revision as of 01:31, 6 November 2023
Defined in header <coroutine>
|
||
constexpr bool operator==( std::coroutine_handle<> x, std::coroutine_handle<> y ) noexcept; |
(1) | (since C++20) |
constexpr std::strong_ordering operator<=>( std::coroutine_handle<> x, std::coroutine_handle<> y ) noexcept; |
(2) | (since C++20) |
Compares two std::coroutine_handle<> values x and y according to their underlying addresses.
The <
, <=
, >
, >=
, and !=
operators are synthesized from operator<=> and operator== respectively.
Contents |
[edit] Parameters
x, y | - | std::coroutine_handle<> values to compare |
[edit] Return value
1) x.address() == y.address()
2) std::compare_three_way{}(x.address(), y.address())
[edit] Notes
Although these operators are only overloaded for std::coroutine_handle<>, other specializations of std::coroutine_handle are also equality comparable and three-way comparable, because they are implicitly convertible to std::coroutine_handle<>.
[edit] Example
This section is incomplete Reason: no example |