std::expected - cppreference.com (original) (raw)

Defined in header
template< class T, class E > class expected; (1) (since C++23)
template< class T, class E > requires std::is_void_v<T> class expected<T, E>; (2) (since C++23)

The class template std::expected provides a way to represent either of two values: an expected value of type T, or an unexpected value of type E. expected is never valueless.

  1. The main template. Contains the expected or unexpected value within its own storage, which is nested within the expected object.

  2. The void partial specialization. Represents an expected void value or contains an unexpected value. If it contains an unexpected value, it is nested within the expected object.

A program is ill-formed if it instantiates an expected with a reference type, a function type, or a specialization of std::unexpected. In addition, T must not be std::in_place_t or std::unexpect_t.

Contents

[edit] Template parameters

T - the type of the expected value. The type must either be (possibly cv-qualified) void, or meet the Destructible requirements (in particular, array and reference types are not allowed).
E - the type of the unexpected value. The type must meet the Destructible requirements, and must be a valid template argument for std::unexpected (in particular, arrays, non-object types, and cv-qualified types are not allowed).

[edit] Nested types

[edit] Member templates

Template Definition
rebind<U> std::expected<U, error_type>

[edit] Data members

Member Description
bool has_val whether the expected object currently represents the expected value(exposition-only member object*)
T val (main template only) the expected value(exposition-only variant member object*)
E unex the unexpected value(exposition-only variant member object*)

[edit] Member functions

(constructor) constructs the expected object (public member function) [edit]
(destructor) destroys the expected object, along with its contained value (public member function) [edit]
operator= assigns contents (public member function) [edit]
Observers
operator->operator* accesses the expected value (public member function) [edit]
operator boolhas_value checks whether the object contains an expected value (public member function) [edit]
value returns the expected value (public member function) [edit]
error returns the unexpected value (public member function) [edit]
value_or returns the expected value if present, another value otherwise (public member function) [edit]
error_or returns the unexpected value if present, another value otherwise (public member function) [edit]
Monadic operations
and_then returns the result of the given function on the expected value if it exists; otherwise, returns the expected itself (public member function) [edit]
transform returns an expected containing the transformed expected value if it exists; otherwise, returns the expected itself (public member function) [edit]
or_else returns the expected itself if it contains an expected value; otherwise, returns the result of the given function on the unexpected value (public member function) [edit]
transform_error returns the expected itself if it contains an expected value; otherwise, returns an expected containing the transformed unexpected value (public member function) [edit]
Modifiers
emplace constructs the expected value in-place (public member function) [edit]
swap exchanges the contents (public member function) [edit]

[edit] Non-member functions

[edit] Helper classes

[edit] Notes

Types with the same functionality are called Result in Rust and Either in Haskell.

Feature-test macro Value Std Feature
__cpp_lib_expected 202202L (C++23) class template std::expected and associated helper classes
202211L (C++23) Monadic functions for std::expected

[edit] Example

#include #include #include #include #include   enum class parse_error { invalid_input, overflow };   auto parse_number(std::string_view& str) -> std::expected<double, parse_error> { const char* begin = str.data(); char* end; double retval = std::strtod(begin, &end);   if (begin == end) return std::unexpected(parse_error::invalid_input); else if (std::isinf(retval)) return std::unexpected(parse_error::overflow);   str.remove_prefix(end - begin); return retval; }   int main() { auto process = str) { std::cout << "str: " << std::quoted(str) << ", "; if (const auto num = parse_number(str); num.has_value()) std::cout << "value: " << *num << '\n'; // If num did not have a value, dereferencing num // would cause an undefined behavior, and // num.value() would throw std::bad_expected_access. // num.value_or(123) uses specified default value 123. else if (num.error() == parse_error::invalid_input) std::cout << "error: invalid input\n"; else if (num.error() == parse_error::overflow) std::cout << "error: overflow\n"; else std::cout << "unexpected!\n"; // or invoke std::unreachable(); };   for (auto src : {"42", "42abc", "meow", "inf"}) process(src); }

Output:

str: "42", value: 42 str: "42abc", value: 42 str: "meow", error: invalid input str: "inf", error: overflow

[edit] Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
LWG 4141 C++23 the requirement of storageallocation was confusing the contained object must benested within the expected object

[edit] References

[edit] See also

| | a type-safe discriminated union (class template) [edit] | | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | | | a wrapper that may or may not hold an object (class template) [edit] |