std::optional<T>::value

来自cppreference.com
< cpp‎ | utility‎ | optional
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (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)
 
std::optional
成员函数
观察器
optional::value
(C++17)
单子操作
修改器
非成员函数
(C++17)(C++17)(C++17)(C++17)(C++17)(C++17)(C++20)
(C++17)
推导指引
辅助类
(C++17)
(C++17)
(C++17)
辅助对象
(C++17)
(C++17)
 
constexpr T& value() &;
constexpr const T& value() const&;
(1) (C++17 起)
constexpr T&& value() &&;
constexpr const T&& value() const&&;
(2) (C++17 起)

*this 含值,则返回到所含值引用。

否则,抛出 std::bad_optional_access 异常。

参数

(无)

返回值

到所含值的引用。

异常

*this 不含值则抛出 std::bad_optional_access

注解

解引用运算符 operator*() 不检查此 optional 是否含值,它可能比 value() 更有效率。

示例

#include <optional>
#include <iostream>
int main()
{
    std::optional<int> opt = {};
 
    try {
        int n = opt.value();
    } catch(const std::exception& e) {
        std::cout << e.what() << '\n';
    }
}

可能的输出:

bad optional access

参阅

若所含值可用则返回它,否则返回另一个值
(公开成员函数)
访问所含值
(公开成员函数)
指示进行了到不含值的 optional 的有检查访问的异常
(类)