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

来自cppreference.com
< cpp‎ | utility‎ | expected
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
 
template< class F >
constexpr auto or_else( F&& f ) &;
(1) (C++23 起)
template< class F >
constexpr auto or_else( F&& f ) const&;
(2) (C++23 起)
template< class F >
constexpr auto or_else( F&& f ) &&;
(3) (C++23 起)
template< class F >
constexpr auto or_else( F&& f ) const&&;
(4) (C++23 起)

如果 *this 包含不期待的值,调用 f 并返回其结果;否则,返回一个包含了 value() 的复制的 std::expected 对象。包含的不期待的值( error() )将作为参数传递给 f

G 为:

  • 对于重载 (1-2)std::remove_cvref_t<std::invoke_result_t<F, decltype(error())>>
  • 对于重载 (3-4)std::remove_cvref_t<std::invoke_result_t<F, decltype(std::move(error()))>>

返回值类型是 G ,其必须是 std::expected 的特化,且 std::is_same_v<G::value_type, T> 必须为 true

1-2) 等价于
if (has_value())
{
    if constexpr (std::is_void_v<T>)
        return G();
    else
        return G(std::in_place, value());
}
else
{
    return std::invoke(std::forward<F>(f), error());
}
这些重载只有在 std::is_void_v<T>std::is_constructible_v<T, decltype(value())>true 时才会参与重载决议.
3-4) 等价于
if (has_value())
{
    if constexpr (std::is_void_v<T>)
        return G();
    else
        return G(std::in_place, std::move(value()));
}
else
{
    return std::invoke(std::forward<F>(f), std::move(error()));
}
这些重载只有在 std::is_void_v<T>std::is_constructible_v<T, decltype(std::move(value()))>true时才会参与重载决议.

参数

f - 适合的函数或 可调用 (Callable) 对象,返回 std::expected

返回值

f 的结果或包含期待的值的 std::expected 的对象,如上所述

注解

功能特性测试 标准 注释
__cpp_lib_expected 202211L (C++23) std::expected 的单子函数

示例

参阅

若含有期待的值则返回 expected 本身,否则返回含有变换后不期待的值的 expected
(公开成员函数)