Namensräume
Varianten
Aktionen

std::make_optional

Von cppreference.com
< cpp‎ | utility‎ | optional
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
Definiert in der Header-Datei <optional>
template< class T >
constexpr std::optional<std::decay_t<T>> make_optional( T&& value );
(1) (seit C++17)
template< class T, class... Args >
constexpr std::optional<T> make_optional( Args&&... args );
(2) (seit C++17)
template< class T, class U, class... Args >

constexpr std::optional<T> make_optional( std::initializer_list<U> il,

                                          Args&&... args );
(3) (seit C++17)
1) Erzeugt ein optionales Objekt aus value. Ruft effektiv auf std::optional<std::decay_t<T>>(std::forward<T>(value)).
2) Erzeugt ein optionales Objekt, das In-Place aus args... konstruiert wird. Äquivalent zu return std::optional<T>(std::in_place, std::forward<Args>(args)...);.
Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_constructible_v<T, Args...> true ist.
3) Erzeugt ein optionales Objekt, das In-Place aus il und args... konstruiert wird. Äquivalent zu return std::optional<T>(std::in_place, il, std::forward<Args>(args)...);.
Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_constructible_v<T, std::initializer_list<U>&, Args...> true ist.

Inhalt

[bearbeiten] Parameter

value - Der Wert, mit dem das optionale Objekt konstruiert werden soll
il, args - Argumente, die an den Konstruktor von T übergeben werden sollen

[bearbeiten] Rückgabewert

Das konstruierte optionale Objekt.

[bearbeiten] Ausnahmen

Wirft jede Ausnahme, die vom Konstruktor von T geworfen wird.

[bearbeiten] Anmerkungen

T muss nicht verschiebbar sein für Überladungen (2,3) aufgrund von garantierter Kopierelision.

[bearbeiten] Beispiel

#include <iomanip>
#include <iostream>
#include <optional>
#include <string>
#include <vector>
 
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: " << std::quoted(op3.value_or("empty value")) << '\n';
    std::cout << "str: " << std::quoted(str) << '\n';
}

Mögliche Ausgabe

op1: a,b,c,
op2: 2,2,2,2,2,
op3: "hello world"
str: ""

[bearbeiten] Siehe auch

konstruiert das optional-Objekt
(öffentliche Member-Funktion) [bearbeiten]