Пространства имён
Варианты
Действия

std::optional<T>::operator->, std::optional<T>::operator*

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
std::optional
Функции-элементы
Наблюдатели
Монадические операции
Модификаторы
Функции, не являющиеся элементами
Правила вывода
Вспомогательные классы
Вспомогательные объекты
 
<tbody> </tbody>
constexpr const T* operator->() const noexcept;
(1) (начиная с C++17)
constexpr T* operator->() noexcept;
(1) (начиная с C++17)
constexpr const T& operator*() const& noexcept;
(2) (начиная с C++17)
constexpr T& operator*() & noexcept;
(2) (начиная с C++17)
constexpr const T&& operator*() const&& noexcept;
(2) (начиная с C++17)
constexpr T&& operator*() && noexcept;
(2) (начиная с C++17)

Доступ к содержащемуся значению.

1) Возвращает указатель на содержащееся значение.
2) Возвращает ссылку на содержащееся значение.

Поведение не определено, если *this не содержит значения.

Параметры

(нет)

Возвращаемое значение

Указатель или ссылка на содержащееся значение.

Примечание

Этот оператор не проверяет, содержит ли optional значение! Вы можете сделать это вручную, используя has_value() или просто operator bool(). В качестве альтернативы, если требуется проверенный доступ, можно использовать value() или value_or().

Пример

#include <optional>
#include <iostream>
#include <iomanip>
#include <string>

int main()
{
    using namespace std::string_literals;
 
    std::optional<int> opt1 = 1;
    std::cout<< "opt1: " << *opt1 << '\n';
    
    *opt1 = 2;
    std::cout<< "opt1: " << *opt1 << '\n';
 
    std::optional<std::string> opt2 = "абв"s;
    std::cout<< "opt2: " << std::quoted(*opt2) << " размер: " << opt2->size() << '\n';
    
    // Вы можете "взять" содержащееся значение, вызвав operator*
    // для rvalue объекта optional
    
    auto taken = *std::move(opt2);
    std::cout << "taken: " << std::quoted(taken) << '\n'
              << "opt2: " << std::quoted(*opt2)
              << ", размер: " << opt2->size()  << '\n';
}

Вывод:

opt1: 1
opt1: 2
opt2: абв размер: 3
taken: абв
opt2: "", размер: 0

Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

Номер Применён Поведение в стандарте Корректное поведение
LWG 2762 C++17 operator-> и operator* могут быть потенциально генерирующими исключения сделаны noexcept

Смотрите также

возвращает содержащееся значение
(public функция-элемент) [править]
возвращает содержащееся значение, если доступно, иначе другое значение
(public функция-элемент) [править]