std::expected<T,E>::transform_error
来自 cppreference.cn
主模板 |
||
template< class F > constexpr auto transform_error( F&& f ) &; |
(1) | (C++23 起) |
template< class F > constexpr auto transform_error( F&& f ) const&; |
(2) | (C++23 起) |
template< class F > constexpr auto transform_error( F&& f ) &&; |
(3) | (C++23 起) |
template< class F > constexpr auto transform_error( F&& f ) const&&; |
(4) | (C++23 起) |
void 偏特化 |
||
template< class F > constexpr auto transform_error( F&& f ) &; |
(5) | (C++23 起) |
template< class F > constexpr auto transform_error( F&& f ) const&; |
(6) | (C++23 起) |
template< class F > constexpr auto transform_error( F&& f ) &&; |
(7) | (C++23 起) |
template< class F > constexpr auto transform_error( F&& f ) const&&; |
(8) | (C++23 起) |
如果 *this 包含一个非预期值,则调用 f,并将 *this 的非预期值作为参数,返回一个包含非预期值的 std::expected
对象,该非预期值用 f 的结果初始化。否则,返回一个表示预期值的 std::expected
对象。
给定类型 G
为
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()))>>
如果满足以下任何条件,程序将不正确:
-
G
不是std::unexpected
的有效模板参数。 - 以下相应的声明格式错误:
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()));
目录 |
[edit] 参数
f | - | 一个合适的函数或可调用 (Callable) 对象,其调用签名返回一个非引用类型 |
[edit] 返回值
给定表达式 expr 为
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()))
返回值定义如下:
重载 | 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] 示例
本节不完整 原因:无示例 |
[edit] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 3938 | C++23 | 期望值通过 value()[1] 获得 | 更改为 **this |
LWG 3973 | C++23 | 期望值通过 **this[2] 获得 | 更改为 val |
[edit] 参阅
如果 `expected` 包含一个预期值,则返回 `expected` 本身;否则,返回给定函数对非预期值的结果。 (public member function) | |
如果预期值存在,返回包含转换后的预期值的 expected ;否则返回 expected 自身(public member function) |