Namensräume
Varianten
Aktionen

std::expected<T,E>::operator->, std::expected<T,E>::operator*

Von cppreference.com
< cpp‎ | utility‎ | expected
 
 
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)
 
 
Primäre Vorlage
constexpr const T* operator->() const noexcept;
(1) (seit C++23)
constexpr T* operator->() noexcept;
(2) (seit C++23)
constexpr const T& operator*() const& noexcept;
(3) (seit C++23)
constexpr T& operator*() & noexcept;
(4) (seit C++23)
constexpr const T&& operator*() const&& noexcept;
(5) (seit C++23)
constexpr T&& operator*() && noexcept;
(6) (seit C++23)
void partielle Spezialisierung
constexpr void operator*() const noexcept;
(7) (seit C++23)

Greift auf den enthaltenen Wert des std::expected zu.

1,2) Gibt einen Zeiger auf den erwarteten Wert zurück.
3-6) Gibt eine Referenz auf den erwarteten Wert zurück.
7) Gibt nichts zurück.

Wenn has_value() false ist, ist das Verhalten undefiniert.

Inhalt

[edit] Rückgabewert

3,4) val
5,6) std::move(val)

[edit] Hinweise

Diese Operatoren prüfen nicht, ob das optional einen erwarteten Wert repräsentiert! Sie können dies manuell tun, indem Sie has_value() oder einfach operator bool() verwenden. Alternativ können Sie, wenn ein geprüfter Zugriff benötigt wird, value() oder value_or() verwenden.

[edit] Beispiel

#include <cassert>
#include <expected>
#include <iomanip>
#include <iostream>
#include <string>
 
int main()
{
    using namespace std::string_literals;
 
    std::expected<int, std::string> ex1 = 6;
    assert(*ex1 == 6);
 
    *ex1 = 9;
    assert(*ex1 == 9);
 
    // *ex1 = "error"s; // error, ex1 contains an expected value of type int
    ex1 = std::unexpected("error"s);
    // *ex1 = 13; // UB, ex1 contains an unexpected value
    assert(ex1.value_or(42) == 42);
 
    std::expected<std::string, bool> ex2 = "Moon"s;
    std::cout << "ex2: " << std::quoted(*ex2) << ", size: " << ex2->size() << '\n';
 
    // You can "take" the expected value by calling operator* on an std::expected rvalue
 
    auto taken = *std::move(ex2);
    std::cout << "taken " << std::quoted(taken) << "\n"
                 "ex2: " << std::quoted(*ex2) << ", size: " << ex2->size() << '\n';
}

Mögliche Ausgabe

ex2: "Moon", size: 4
taken "Moon"
ex2: "", size: 0

[edit] Siehe auch

gibt den erwarteten Wert zurück
(öffentliche Mitgliedsfunktion) [bearbeiten]
gibt den erwarteten Wert zurück, falls vorhanden, andernfalls einen anderen Wert
(öffentliche Mitgliedsfunktion) [bearbeiten]
prüft, ob das Objekt einen erwarteten Wert enthält
(öffentliche Mitgliedsfunktion) [bearbeiten]
gibt den unerwarteten Wert zurück
(öffentliche Mitgliedsfunktion) [bearbeiten]