命名空间
变体
操作

std::expected<T,E>::expected

来自 cppreference.cn
< cpp‎ | 工具库‎ | expected
 
 
 
 
Main template
constexpr expected();
(1) (C++23 起)
constexpr expected( const expected& other );
(2) (C++23 起)
constexpr expected( expected&& other ) noexcept(/* see below */);
(3) (C++23 起)
template< class U, class G >
constexpr expected( const expected<U, G>& other );
(4) (C++23 起)
(conditionally explicit)
template< class U, class G >
constexpr expected( expected<U, G>&& other );
(5) (C++23 起)
(conditionally explicit)
template< class U = std::remove_cv_t<T> >
constexpr explicit(!std::is_convertible_v<U, T>) expected( U&& v );
(6) (C++23 起)
template< class G >

constexpr explicit(!std::is_convertible_v<const G&, E>)

    expected( const std::unexpected<G>& e );
(7) (C++23 起)
template< class G >

constexpr explicit(!std::is_convertible_v<G, E>)

    expected( std::unexpected<G>&& e );
(8) (C++23 起)
template< class... Args >
constexpr explicit expected( std::in_place_t, Args&&... args );
(9) (C++23 起)
template< class U, class... Args >

constexpr explicit
    expected( std::in_place_t,

              std::initializer_list<U> il, Args&&... args );
(10) (C++23 起)
template< class... Args >
constexpr explicit expected( std::unexpect_t, Args&&... args );
(11) (C++23 起)
template< class U, class... Args >

constexpr explicit
    expected( std::unexpect_t,

              std::initializer_list<U> il, Args&&... args );
(12) (C++23 起)
void 偏特化
constexpr expected();
(13) (C++23 起)
constexpr expected( const expected& other );
(14) (C++23 起)
constexpr expected( expected&& other )
    noexcept(std::is_nothrow_move_constructible_v<E>);
(15) (C++23 起)
template< class U, class G >

constexpr explicit(!std::is_convertible_v<const G&, E>)

    expected( const expected<U, G>& other );
(16) (C++23 起)
template< class U, class G >

constexpr explicit(!std::is_convertible_v<G, E>)

    expected( expected<U, G>&& other );
(17) (C++23 起)
template< class G >

constexpr explicit(!std::is_convertible_v<const G&, E>)

    expected( const std::unexpected<G>& e );
(18) (C++23 起)
template< class G >

constexpr explicit(!std::is_convertible_v<G, E>)

    expected( std::unexpected<G>&& e );
(19) (C++23 起)
template< class... Args >
constexpr explicit expected( std::in_place_t );
(20) (C++23 起)
template< class... Args >
constexpr explicit expected( std::unexpect_t, Args&&... args );
(21) (C++23 起)
template< class U, class... Args >

constexpr explicit
    expected( std::unexpect_t,

              std::initializer_list<U> il, Args&&... args );
(22) (C++23 起)

构造一个新的 expected 对象。

目录

[编辑] 参数

其他 - 另一个 expected 对象,其包含的值被复制
e - std::unexpected 对象,其包含的值被复制
v - 用于初始化包含值的值
args - 用于初始化包含值的参数
il - 用于初始化包含值的初始化列表

[编辑] 效果

[编辑] 主模板构造函数

重载 初始化
方法
初始化器用于... has_value()
构造后
预期值 非预期值
(1) (空) - true
(2) 直接
(非列表)
*other other.error() other.has_value()
  • 如果为 true,则只初始化预期值。
  • 如果为 false,则只初始化非预期值。
(3) std::move(*other) std::move(other.error())
(4) std::forward<const U&>
    (*other)
std::forward<const G&>
    (other.error())
(5) std::forward<U>(*other) std::forward<G>
    (other.error())
(6) std::forward<U>(v) - true
(7) - std::forward<const G&>
    (e.error())
false
(8) std::forward<G>(e.error())
(9) std::forward<Args>(args)... - true
(10) il,
std::forward<Args>(args)...
(11) - std::forward<Args>(args)... false
(12) il,
std::forward<Args>(args)...

[编辑] void 部分特化构造函数

重载 初始化方法 非预期值的初始化器 has_value() 构造后
(13) 不适用 - true
(14) 直接(非列表) rhs.error() other.has_value()
  • 如果为 false,则初始化非预期值。
(15) std::move(rhs.error)
(16) std::forward<const G&>(rhs.error())
(17) std::forward<G>(rhs.error())
(18) std::forward<const G&>(e.error()) false
(19) std::forward<G>(e.error())
(20) 不适用 - true
(21) 直接(非列表) std::forward<Args>(args)... false
(22) il, std::forward<Args>(args)...

[编辑] 约束和补充信息

[编辑] 主模板构造函数

1) 仅当 std::is_default_constructible_v<T>true 时,此重载才参与重载决议。
2) 除非 std::is_copy_constructible_v<T>std::is_copy_constructible_v<E> 都为 true,否则此构造函数被定义为删除。
如果 std::is_trivially_copy_constructible_v<T>std::is_trivially_copy_constructible_v<E> 都为 true,则此构造函数是平凡的。
3) 仅当 std::is_move_constructible_v<T>std::is_move_constructible_v<E> 都为 true 时,此重载才参与重载决议。
如果 std::is_trivially_move_constructible_v<T>std::is_trivially_move_constructible_v<E> 都为 true,则此构造函数是平凡的。
4,5) 仅当满足以下所有条件时,这些重载才参与重载决议
4) 如果 std::is_convertible_v<const U&, T>std::is_convertible_v<const G&, E>false,则此构造函数是 explicit 的。
5) 如果 std::is_convertible_v<U, T>std::is_convertible_v<G, E>false,则此构造函数是 explicit 的。
6) 仅当满足以下所有条件时,此重载才参与重载决议
7) 此重载仅在 std::is_constructible_v<E, const G&>true 时参与重载决议。
8) 此重载仅在 std::is_constructible_v<E, G>true 时参与重载决议。
9) 此重载仅在 std::is_constructible_v<T, Args...>true 时参与重载决议。
10) 此重载仅在 std::is_constructible_v<T, std::initializer_list<U>&, Args...>true 时参与重载决议。
11) 此重载仅在 std::is_constructible_v<E, Args...>true 时参与重载决议。
12) 此重载仅在 std::is_constructible_v<E, std::initializer_list<U>&, Args...>true 时参与重载决议。

[编辑] void 偏特化构造函数

14) 此构造函数被定义为已删除,除非 std::is_copy_constructible_v<E>true
如果 std::is_trivially_copy_constructible_v<E>true,则此构造函数是平凡的。
15) 此重载仅在 std::is_move_constructible_v<E>true 时参与重载决议。
如果 std::is_trivially_move_constructible_v<E>true,则此构造函数是平凡的。
16,17) 这些重载仅在满足以下所有条件时参与重载决议
18) 此重载仅在 std::is_constructible_v<E, const G&>true 时参与重载决议。
19) 此重载仅在 std::is_constructible_v<E, G>true 时参与重载决议。
21) 此重载仅在 std::is_constructible_v<E, Args...>true 时参与重载决议。
22) 此重载仅在 std::is_constructible_v<E, std::initializer_list<U>&, Args...>true 时参与重载决议。

[编辑] 异常

[编辑] 主模板构造函数

1) 抛出由 expected 值初始化引发的任何异常。
2) 抛出由 expected 或 unexpected 值初始化引发的任何异常。
3) 抛出由 expected 或 unexpected 值初始化引发的任何异常。
4,5) 抛出由 expected 或 unexpected 值初始化引发的任何异常。
6) 抛出由 expected 值初始化引发的任何异常。
7,8) 抛出由 unexpected 值初始化引发的任何异常。
9,10) 抛出由 expected 值初始化引发的任何异常。
11,12) 抛出由 unexpected 值初始化引发的任何异常。

[编辑] void 偏特化构造函数

14-19) 抛出由 unexpected 值初始化引发的任何异常。
21,22) 抛出由 unexpected 值初始化引发的任何异常。

[编辑] 示例

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 3886 C++23 重载 (6) 的默认模板参数是 T 改为 std::remove_cv_t<T>

[编辑] 另请参见

表示为意外值
(类模板) [编辑]
原地构造标签
(标签)[编辑]
用于 expected 中非预期值就地构造的标签
(标签)[编辑]
English 日本語 中文(简体) 中文(繁體)