std::optional<T>::value

来自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)

 
 
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 <iostream>
#include <optional>
 
int main()
{
    std::optional<int> opt = {};
 
    try
    {
        [[maybe_unused]] int n = opt.value();
    }
    catch(const std::bad_optional_access& e)
    {
        std::cout << e.what() << '\n';
    }
 
    try
    {
        opt.value() = 42;
    }
    catch(const std::bad_optional_access& e)
    {
        std::cout << e.what() << '\n';
    }
 
    opt = 43;
    std::cout << *opt << '\n';
 
    opt.value() = 44;
    std::cout << opt.value() << '\n';
}

输出:

bad optional access
bad optional access
43
44

参阅

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