命名空间
变体
操作

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*() 不检查此可选对象是否包含值,这可能比 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

[编辑] 参见

如果可用,则返回所包含的值,否则返回另一个值
(公有成员函数) [编辑]
访问所包含的值
(公有成员函数) [编辑]
指示对不包含值的可选对象进行检查访问的异常
(类) [编辑]