std::expected<T,E>::operator->, std::expected<T,E>::operator*
Von cppreference.com
| 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
1,2) std::addressof(
val)3,4)
val5,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
Führen Sie diesen Code aus
#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) | |
| gibt den erwarteten Wert zurück, falls vorhanden, andernfalls einen anderen Wert (öffentliche Mitgliedsfunktion) | |
| prüft, ob das Objekt einen erwarteten Wert enthält (öffentliche Mitgliedsfunktion) | |
| gibt den unerwarteten Wert zurück (öffentliche Mitgliedsfunktion) |