std::expected<T,E>::transform_error
Von cppreference.com
| Primäre Vorlage |
||
template< class F > constexpr auto transform_error( F&& f ) &; |
(1) | (seit C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&; |
(2) | (seit C++23) |
template< class F > constexpr auto transform_error( F&& f ) &&; |
(3) | (seit C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&&; |
(4) | (seit C++23) |
| void partielle Spezialisierung |
||
template< class F > constexpr auto transform_error( F&& f ) &; |
(5) | (seit C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&; |
(6) | (seit C++23) |
template< class F > constexpr auto transform_error( F&& f ) &&; |
(7) | (seit C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&&; |
(8) | (seit C++23) |
Wenn *this einen unerwarteten Wert enthält, wird f mit dem unerwarteten Wert von *this als Argument aufgerufen und ein `std::expected`-Objekt zurückgegeben, das einen unerwarteten Wert enthält, welcher mit dem Ergebnis von f initialisiert wird. Andernfalls wird ein `std::expected`-Objekt zurückgegeben, das einen erwarteten Wert darstellt.
Gegebener Typ G als
1,2) std::remove_cv_t<std::invoke_result_t<F, decltype(error())>>
3,4) std::remove_cv_t<std::invoke_result_t<F, decltype(std::move(error()))>>
5,6) std::remove_cv_t<std::invoke_result_t<F, decltype(error())>>
7,8) std::remove_cv_t<std::invoke_result_t<F, decltype(std::move(error()))>>
Wenn eine der folgenden Bedingungen erfüllt ist, ist das Programm ill-formed (wohlgeformt):
-
Gist kein gültiges Template-Argument fürstd::unexpected. - Die folgende entsprechende Deklaration ist ill-formed
1,2) G g(std::invoke(std::forward<F>(f), error()));
3,4) G g(std::invoke(std::forward<F>(f), std::move(error()));
5,6) G g(std::invoke(std::forward<F>(f), error()));
7,8) G g(std::invoke(std::forward<F>(f), std::move(error()));
1,2) Diese Überladung nimmt an der Überladungsauflösung teil, nur wenn std::is_constructible_v<T, decltype((
val))> true ist.3,4) Diese Überladung nimmt an der Überladungsauflösung teil, nur wenn std::is_constructible_v<T, decltype(std::move(
val))> true ist.Inhalt |
[edit] Parameter
| f | - | ein geeignetes aufrufbares Objekt oder eine geeignete Callable, dessen Aufrufsignatur einen Nicht-Referenztyp zurückgibt |
[edit] Rückgabewert
Ausdruck expr als
1,2) std::invoke(std::forward<F>(f), error())
3,4) std::invoke(std::forward<F>(f), std::move(error()))
5,6) std::invoke(std::forward<F>(f), error())
7,8) std::invoke(std::forward<F>(f), std::move(error()))
Die Rückgabewerte sind wie folgt definiert
| Überladung | Wert von has_value() | |
|---|---|---|
| true | false | |
| (1,2) | std::expected<T, G>(std::in_place, val)
|
std::expected<T, G> (std::unexpect, expr) |
| (3,4) | std::expected<T, G>(std::in_place, std::move(val))
| |
| (5,6) | std::expected<T, G>() | |
| (7,8) | ||
[edit] Beispiel
| Dieser Abschnitt ist unvollständig Grund: kein Beispiel |
[edit] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 3938 | C++23 | der erwartete Wert wurde durch value()[1] erhalten | geändert zu **this |
| LWG 3973 | C++23 | der erwartete Wert wurde durch **this[2] erhalten | geändert zu val |
- ↑
value()erfordert, dassEkopierkonstruierbar ist (siehe LWG issue 3843), währendoperator*dies nicht tut. - ↑ **this kann Argument-dependent lookup auslösen.
[edit] Siehe auch
gibt das expected selbst zurück, wenn es einen erwarteten Wert enthält; andernfalls gibt es das Ergebnis der gegebenen Funktion auf dem unerwarteten Wert zurück(öffentliche Member-Funktion) | |
gibt ein expected mit dem transformierten erwarteten Wert zurück, falls dieser existiert; andernfalls gibt es das expected selbst zurück(öffentliche Mitgliedsfunktion) |