std::expected<T,E>::expected
来自 cppreference.cn
| 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>) |
(7) | (C++23 起) |
template< class G > constexpr explicit(!std::is_convertible_v<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 |
(10) | (C++23 起) |
template< class... Args > constexpr explicit expected( std::unexpect_t, Args&&... args ); |
(11) | (C++23 起) |
template< class U, class... Args > constexpr explicit |
(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>) |
(16) | (C++23 起) |
template< class U, class G > constexpr explicit(!std::is_convertible_v<G, E>) |
(17) | (C++23 起) |
template< class G > constexpr explicit(!std::is_convertible_v<const G&, E>) |
(18) | (C++23 起) |
template< class G > constexpr explicit(!std::is_convertible_v<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 |
(22) | (C++23 起) |
构造一个新的 expected 对象。
目录 |
[编辑] 参数
| 其他 | - | 另一个 expected 对象,其包含的值被复制 |
| e | - | std::unexpected 对象,其包含的值被复制 |
| v | - | 用于初始化包含值的值 |
| args | - | 用于初始化包含值的参数 |
| il | - | 用于初始化包含值的初始化列表 |
[编辑] 效果
[编辑] 主模板构造函数
| 重载 | 初始化 方法 |
初始化器用于... | has_value()构造后 | |
|---|---|---|---|---|
| 预期值 | 非预期值 | |||
| (1) | 值 | (空) | - | true |
| (2) | 直接 (非列表) |
*other | other.error() | other.has_value()
|
| (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()
|
| (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)... |
[编辑] 约束和补充信息
[编辑] 主模板构造函数
如果 std::is_trivially_copy_constructible_v<T> 和 std::is_trivially_copy_constructible_v<E> 都为 true,则此构造函数是平凡的。
如果 std::is_trivially_move_constructible_v<T> 和 std::is_trivially_move_constructible_v<E> 都为 true,则此构造函数是平凡的。
4,5) 仅当满足以下所有条件时,这些重载才参与重载决议
- 对于重载 (4),std::is_constructible_v<T, const U&> 和 std::is_constructible_v<E, const G&> 都为 true。
- 对于重载 (5),std::is_constructible_v<T, U> 和 std::is_constructible_v<E, G> 都为 true。
- 如果
T不是(可能 cv 限定的)bool,则以下 8 个值都为 false- std::is_constructible_v<T, std::expected<U, G>&>
- std::is_constructible_v<T, std::expected<U, G>>
- std::is_constructible_v<T, const std::expected<U, G>&>
- std::is_constructible_v<T, const std::expected<U, G>>
- std::is_convertible_v<std::expected<U, G>&, T>
- std::is_convertible_v<std::expected<U, G>, T>
- std::is_convertible_v<const std::expected<U, G>&, T>
- std::is_convertible_v<const std::expected<U, G>, T>
- 以下 4 个值都为 false
- std::unexpected<E>, std::expected<U, G>&, T>
- std::is_constructible_v<std::unexpected<E>, std::expected<U, G>>
- std::is_constructible_v<std::unexpected<E>, const std::expected<U, G>&>
- std::is_constructible_v<std::unexpected<E>, const std::expected<U, G>>
4) 如果 std::is_convertible_v<const U&, T> 或 std::is_convertible_v<const G&, E> 为 false,则此构造函数是 explicit 的。
6) 仅当满足以下所有条件时,此重载才参与重载决议
- std::is_same_v<std::remove_cvref_t<U>, std::in_place_t> 为 false。
- std::is_same_v<std::expected<T, E>, std::remove_cvref_t<U>> 为 false。
- std::is_constructible_v<T, U> 为 true。
- std::remove_cvref_t<U> 不是
std::unexpected的特化。 - 如果
T是(可能带有 cv 限定符的)bool,则 std::remove_cvref_t<U> 不是std::expected的特化。
[编辑] void 偏特化构造函数
如果 std::is_trivially_copy_constructible_v<E> 为 true,则此构造函数是平凡的。
如果 std::is_trivially_move_constructible_v<E> 为 true,则此构造函数是平凡的。
16,17) 这些重载仅在满足以下所有条件时参与重载决议
- 对于重载 (16),std::is_constructible_v<E, const G&> 为 true。
- 对于重载 (17),std::is_constructible_v<E, G> 为 true。
- std::is_void_v<U> 为 true。
- 以下 4 个值都为 false
- std::unexpected<E>, std::expected<U, G>&, T>
- std::is_constructible_v<std::unexpected<E>, std::expected<U, G>>
- std::is_constructible_v<std::unexpected<E>, const std::expected<U, G>&>
- std::is_constructible_v<std::unexpected<E>, const std::expected<U, G>>
[编辑] 异常
[编辑] 主模板构造函数
1) 抛出由 expected 值初始化引发的任何异常。
2) 抛出由 expected 或 unexpected 值初始化引发的任何异常。
3) 抛出由 expected 或 unexpected 值初始化引发的任何异常。
noexcept 规范:
noexcept(std::is_nothrow_move_constructible_v<T>
&& std::is_nothrow_move_constructible_v<E>)
&& std::is_nothrow_move_constructible_v<E>)
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> |
[编辑] 另请参见
| (C++23) |
表示为意外值 (类模板) |
| 原地构造标签 (标签) | |
| (C++23) |
用于 expected 中非预期值就地构造的标签(标签) |