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

std::make_optional

Материал из 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>
Определено в заголовочном файле <optional>
template< class T > constexpr std::optional<std::decay_t<T>> make_optional( T&& value );
(1) (начиная с C++17)
template< class T, class... Args > constexpr std::optional<T> make_optional( Args&&... args );
(2) (начиная с C++17)
template< class T, class U, class... Args > constexpr std::optional<T> make_optional( std::initializer_list<U> il, Args&&... args );
(3) (начиная с C++17)
1) Создаёт объект optional из value. Эффективно вызывает std::optional<std::decay_t<T>>(std::forward<T>(value)).
2) Создаёт объект optional, сконструированный на месте из args.... Эквивалентно return std::optional<T>(std::in_place, std::forward<Args>(args)...);.
3) Создаёт объект optional, сконструированный на месте из il и args.... Эквивалентно return std::optional<T>(std::in_place, il, std::forward<Args>(args)...);.

Параметры

value значение для создания объекта optional
il, args аргументы для передачи конструктору T.

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

Построенный объект optional.

Исключения

Выдаёт любое исключение, сгенерированное конструктором T.

Примечание

T не обязательно должен быть перемещаемым для перегрузок (2-3) из-за гарантированного пропуска копирования.

Пример

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

int main()
{
    auto op1 = std::make_optional<std::vector<char>>({'a','b','c'});
    std::cout << "op1: ";
    for (char c: op1.value())
        std::cout << c << ',';

    auto op2 = std::make_optional<std::vector<int>>(5, 2);
    std::cout << "\nop2: ";
    for (int i: *op2)
        std::cout << i << ',';

    std::string str{"привет мир"};
    auto op3 = std::make_optional<std::string>(std::move(str));
    std::cout << "\nop3: " << std::quoted(op3.value_or("пустое значение")) << '\n';
    std::cout << "str: " << std::quoted(str) << '\n';
}

Возможный вывод:

op1: a,b,c,
op2: 2,2,2,2,2,
op3: "привет мир"
str: ""

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

создаёт необязательный объект
(public функция-элемент) [править]