Defined in header <optional> | ||
---|---|---|
template< class T > constexpr std::optional<std::decay_t<T>> make_optional( T&& value ); | (1) | (since C++17) |
template< class T, class... Args > constexpr std::optional<T> make_optional( Args&&... args ); | (2) | (since C++17) |
template< class T, class U, class... Args > constexpr std::optional<T> make_optional( std::initializer_list<U> il, Args&&... args ); | (3) | (since C++17) |
value
. Effectively calls std::optional<std::decay_t<T>>(std::forward<T>(value))
args...
. Equivalent to return std::optional<T>(std::in_place, std::forward<Args>(args)...);
.il
and args...
. Equivalent to return std::optional<T>(std::in_place, il, std::forward<Args>(args)...);
.value | - | the value to construct optional object with |
il, args | - | arguments to be passed to the constructor of T . |
The constructed optional object.
Throws any exception thrown by the constructor of T
.
T
need not be movable for overloads (2-3) due to guaranteed copy elision.
#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{"hello world"}; auto op3 = std::make_optional<std::string>(std::move(str)); std::cout << "\nop3: " << quoted(op3.value_or("empty value")) << '\n'; std::cout << "str: " << std::quoted(str) << '\n'; }
Possible output:
op1: a,b,c, op2: 2,2,2,2,2, op3: "hello world" str: ""
constructs the optional object (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/utility/optional/make_optional