std::make_optional
Материал из cppreference.com
<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 функция-элемент) |