命名空间
变体
操作

std::optional<T>::value_or

来自 cppreference.com
< cpp‎ | utility‎ | optional
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库特性测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三向比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(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 U >
constexpr T value_or( U&& default_value ) const&;
(1) (自 C++17 起)
template< class U >
constexpr T value_or( U&& default_value ) &&;
(2) (自 C++17 起)

如果 *this 有值,则返回包含的值,否则返回 default_value

1) 等效于 bool(*this) ? **this : static_cast<T>(std::forward<U>(default_value)).
2) 等效于 bool(*this) ? std::move(**this) : static_cast<T>(std::forward<U>(default_value)).

内容

[编辑] 参数

default_value - 如果 *this 为空,则使用该值
类型要求
-
T 必须满足 可复制构造 的要求才能使用重载 (1)。
-
T 必须满足 可移动构造 的要求才能使用重载 (2)。
-
U&& 必须可转换为 T

[编辑] 返回值

如果 *this 有值,则为当前值,否则为 default_value

[编辑] 异常

返回值 T 的选定构造函数引发的任何异常。

[编辑] 示例

#include <cstdlib>
#include <iostream>
#include <optional>
 
std::optional<const char*> maybe_getenv(const char* n)
{
    if (const char* x = std::getenv(n))
        return x;
    else
        return {};
}
 
int main()
{
    std::cout << maybe_getenv("SHELL").value_or("(none)") << '\n';
    std::cout << maybe_getenv("MYPWD").value_or("(none)") << '\n';
}

可能的输出

/usr/bin/zsh
(none)

[编辑] 另请参见

返回包含的值
(公共成员函数) [编辑]