operator==,!=,<,<=,>,>=,<=>(std::unique_ptr) — cppreference.com
<tbody> </tbody>
| Определено в заголовочном файле |
||
|
|
(1) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(2) | (начиная с C++11) (до C++20) |
|
|
(3) | (начиная с C++11) |
|
|
(4) | (начиная с C++11) |
|
|
(5) | (начиная с C++11) |
|
|
(6) | (начиная с C++11) |
|
|
(7) | (начиная с C++20) |
|
|
(8) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(9) | (начиная с C++11) (до C++20) |
|
|
(10) | (начиная с C++11) (до C++20) |
|
|
(11) | (начиная с C++11) (до C++20) |
|
|
(12) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(13) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(14) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(15) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(16) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(17) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(18) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(19) | (начиная с C++11) (constexpr начиная с C++23) |
|
|
(20) | (начиная с C++20) (constexpr начиная с C++23) |
Сравнивает значения указателя двух unique_ptr или unique_ptr и nullptr.
1-7) Сравнивает два unique_ptr
8-20) Сравнивает unique_ptr и nullptr.
Параметры
| x, y | — | unique_ptr для сравнения
|
Возвращаемое значение
1) x.get() == y.get()
2) x.get() != y.get()
3) std::less<CT>()(x.get(), y.get()), где CT равно std::common_type<unique_ptr<T1, D1>::pointer, unique_ptr<T2, D2>::pointer>::type
4) !(y < x)
5) y < x
6) !(x < y)
7) std::compare_three_way{}(x.get(), y.get())
8,9) !x
10,11) (bool)x
12) std::less<unique_ptr<T,D>::pointer>()(x.get(), nullptr)
13) std::less<unique_ptr<T,D>::pointer>()(nullptr, y.get())
14) !(nullptr < x)
15) !(y < nullptr)
16) nullptr < x
17) y < nullptr
18) !(x < nullptr)
19) !(nullptr < y)
20) std::compare_three_way{}(x.get(), static_cast<typename unique_ptr<T, D>::pointer>(nullptr))
Пример
#include <iostream> #include <memory> int main() { std::unique_ptr<int> p1(new int(42)); std::unique_ptr<int> p2(new int(42)); std::cout << std::boolalpha << "(p1 == p1) : " << (p1 == p1) << '\n' << "(p1 <=> p1) == 0 : " << ((p1 <=> p1) == 0) << '\n' // Начина с C++20 // p1 и p2 указывают на разные ячейки памяти, поэтому p1 != p2 << "(p1 == p2) : " << (p1 == p2) << '\n' << "(p1 < p2) : " << (p1 < p2) << '\n' << "(p1 <=> p2) < 0 : " << ((p1 <=> p2) < 0) << '\n' // Начина с C++20 << "(p1 <=> p2) == 0 : " << ((p1 <=> p2) == 0) << '\n'; // Начина с C++20 }
Возможный вывод:
(p1 == p1) : true (p1 <=> p1) == 0 : true (p1 == p2) : false (p1 < p2) : true (p1 <=> p2) < 0 : true (p1 <=> p2) == 0 : false
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 3426 | C++20 | operator<=>(unique_ptr, nullptr_t) некорректен
|
ограничения и определение зафиксированы |
Смотрите также
| возвращает указатель на управляемый объект (public функция-элемент) [править] |