std::expected<T,E>::operator->, std::expected<T,E>::operator*
Материал из cppreference.com
<tbody>
</tbody>
| T не является cv void |
||
constexpr const T* operator->() const noexcept; |
(1) | (начиная с C++23) |
constexpr T* operator->() noexcept; |
(1) | (начиная с C++23) |
constexpr const T& operator*() const& noexcept; |
(2) | (начиная с C++23) |
constexpr T& operator*() & noexcept; |
(2) | (начиная с C++23) |
constexpr const T&& operator*() const&& noexcept; |
(2) | (начиная с C++23) |
constexpr T&& operator*() && noexcept; |
(2) | (начиная с C++23) |
| T является cv void |
||
constexpr void operator*() const noexcept; |
(3) | (начиная с C++23) |
Обращается к ожидаемому значению, содержащемуся в *this.
1) Возвращает указатель на содержащееся значение.
2) Возвращает ссылку на содержащееся значение.
3) Ничего не возвращает.
Поведение не определено, если this->has_value() равно false.
Параметры
(нет)
Возвращаемое значение
Указатель или ссылка на содержащееся значение.
Примечание
Эти операторы не проверяют, содержит ли необязательный параметр значение! Вы можете сделать это вручную, используя has_value() или просто operator bool(). Альтернативно, если необходим проверенный доступ, можно использовать value() или value_or().
Пример
Запустить этот код
#include <cassert>
#include <expected>
#include <iomanip>
#include <iostream>
#include <string>
int main()
{
using namespace std::string_literals;
std::expected<int, std::string> ex1 = 6;
assert(*ex1 == 6);
*ex1 = 9;
assert(*ex1 == 9);
ex1 = std::unexpected("ошибка"s);
// *ex1 = 13 // Неопределённое поведение, ex1 содержит "неожиданное" значение
assert(ex1.value_or(42) == 42);
std::expected<std::string, bool> ex2 = "Луна"s;
std::cout << "ex2: " << std::quoted(*ex2) << ", размер: " << ex2->size() << '\n';
// Вы можете "взять" содержащееся значение, вызвав operator* для rvalue
// объекта expected
auto taken = *std::move(ex2);
std::cout << "взятый: " << std::quoted(taken) << "\n"
"ex2: " << std::quoted(*ex2) << ", размер: " << ex2->size() << '\n';
}
Возможный вывод:
ex2: "Луна", размер: 8
взятый: "Луна"
ex2: "", размер: 0
Смотрите также
| возвращает ожидаемое значение (public функция-элемент) | |
| возвращает ожидаемое значение, если оно присутствует, иначе другое значение (public функция-элемент) | |
| проверяет, содержит ли объект ожидаемое значение (public функция-элемент) | |
| возвращает неожидаемое значение (public функция-элемент) |