std::optional<T>::value
Материал из cppreference.com
<tbody>
</tbody>
constexpr T& value() &; constexpr const T& value() const &; |
(1) | (начиная с C++17) |
constexpr T&& value() &&; constexpr const T&& value() const &&; |
(2) | (начиная с C++17) |
Если *this содержит значение, возвращает ссылку на содержащееся значение.
Иначе, генерирует исключение std::bad_optional_access.
Параметры
(нет)
Возвращаемое значение
Ссылка на содержащееся значение.
Исключения
std::bad_optional_access, если *this не содержит значения.
Примечание
Оператор разыменования operator*() не проверяет, содержит ли этот optional значение, что может быть более эффективным, чем value().
Пример
Запустить этот код
#include <optional>
#include <iostream>
int main()
{
std::optional<int> opt = {};
try {
[[maybe_unused]] int n = opt.value();
} catch(const std::bad_optional_access& e) {
std::cout << e.what() << '\n';
}
try {
opt.value() = 42;
} catch(const std::bad_optional_access& e) {
std::cout << e.what() << '\n';
}
opt = 43;
std::cout << *opt << '\n';
opt.value() = 44;
std::cout << opt.value() << '\n';
}
Вывод:
bad optional access
bad optional access
43
44
Смотрите также
| возвращает содержащееся значение, если доступно, иначе другое значение (public функция-элемент) | |
| получает доступ к содержащемуся значению (public функция-элемент) | |
(C++17) |
исключение, указывающее на доступ на проверку к optional, не содержащему значения (класс) |