C++ 参考手册
- C++11
- C++14
- C++17
- C++20
- C++ 编译器支持情况表
- 独立与宿主实现
- C++ 语言
- C++ 关键词
- 预处理器
- C++ 标准库头文件
- 具名要求
- 功能特性测试 (C++20)
- 工具库
- 程序支持工具
- std::initializer_list
- 函数对象
- std::hash
- std::pair
- std::tuple
- std::optional
- std::hash <std::optional>
- std::optional<T>::operator->, std::optional<T>::operator*
- std::optional<T>::operator=
- std::optional<T>::optional
- std::optional<T>::~optional
- std::optional<T>::operator bool, std::optional<T>::has_value
- std::optional<T>::value
- std::optional<T>::value_or
- std::optional<T>::emplace
- std::optional<T>::swap
- std::optional<T>::reset
- operator==, !=, <, <=, >, >=, <=>(std::optional)
- std::make_optional
- std::swap(std::optional)
- std::optional 的推导指引
- std::nullopt_t
- std::bad_optional_access
- std::nullopt
- std::apply
- 库特性测试宏 (C++20)
- std::any
- std::variant
- 格式化库 (C++20)
- std::integer_sequence
- std::exchange
- std::make_from_tuple
- std::launder
- std::to_chars
- std::from_chars
- std::as_const
- std::source_location
- 变参数函数
- std::bitset
- std::cmp_equal, cmp_not_equal, cmp_less, cmp_greater, cmp_less_equal, cmp_greater_equal
- std::in_range
- std::declval
- std::forward
- std::move
- std::move_if_noexcept
- std::chars_format
- std::piecewise_construct_t
- std::piecewise_construct
- std::in_place, std::in_place_type, std::in_place_index, std::in_place_t, std::in_place_type_t, std::in_place_index_t
- 注释
- 类型支持(基本类型、RTTI、类型特性)
- 概念库 (C++20)
- 错误处理
- 动态内存管理
- 日期和时间工具
- 字符串库
- 容器库
- 迭代器库
- 范围库 (C++20)
- 算法库
- 数值库
- 输入/输出库
- 文件系统库
- 本地化库
- 正则表达式库
- 原子操作库
- 线程支持库
- 实验性 C++ 特性
- 有用的资源
- 索引
- std 符号索引
- 协程支持 (C++20)
- C++ 关键词
std::optional
定义于头文件 <optional>
|
||
template< class T > class optional; |
(C++17 起) | |
类模板 std::optional
管理一个可选的容纳值,既可以存在也可以不存在的值。
一种常见的 optional
使用情况是一个可能失败的函数的返回值。与其他手段,如 std::pair<T,bool> 相比, optional
良好地处理构造开销高昂的对象,并更加可读,因为它显式表达意图。
任何一个 optional<T>
的实例在给定时间点要么含值,要么不含值。
若一个 optional<T>
含值,则保证值作为 optional
对象所用空间的一部分分配,即不会发生动态内存分配。从而 optional
对象模拟一个对象,而非指针,尽管定义了 operator*() 和 operator->() 运算符。
当一个 optional<T>
对象被按语境转换成 bool 时,若对象含值则转换返回 true ,若对象不含值则返回 false 。
optional
对象在下列条件下含值:
- 对象被以
T
类型值或另一含值的optional
初始化/赋值。
对象在下列条件下不含值:
- 对象被默认初始化。
- 对象被以 std::nullopt_t 类型值或不含值的
optional
对象初始化/赋值。 - 调用了成员函数 reset() 。
无引用的 optional :若以引用类型实例化 optional
则程序非良构。不过,可用 T
类型的 std::reference_wrapper 的 optional
保有引用。另外,若以(可有 cv 限定的)标签类型 std::nullopt_t 或 std::in_place_t 实例化 optional
则程序非良构。
模板形参
T | - | 要为之管理状态的值的类型。该类型必须满足可析构 (Destructible) 的要求。(特别是不允许数组类型) |
成员类型
成员类型 | 定义 |
value_type
|
T
|
成员函数
构造optional 对象 (公开成员函数) | |
销毁容纳的值,若存在 (公开成员函数) | |
对内容赋值 (公开成员函数) | |
观察器 | |
访问所含值 (公开成员函数) | |
检查对象是否含值 (公开成员函数) | |
返回所含值 (公开成员函数) | |
若所含值可用则返回它,否则返回另一个值 (公开成员函数) | |
修改器 | |
交换内容 (公开成员函数) | |
销毁任何所含值 (公开成员函数) | |
原位构造所含值 (公开成员函数) |
非成员函数
(C++17)(C++17)(C++17)(C++17)(C++17)(C++17)(C++20) |
比较 optional 对象 (函数模板) |
(C++17) |
创建一个 optional 对象 (函数模板) |
(C++17) |
特化 std::swap 算法 (函数) |
辅助类
(C++17) |
特化 std::hash 算法 (类模板特化) |
(C++17) |
带未初始化状态的 optional 类型的指示器 (类) |
(C++17) |
指示进行了到不含值的 optional 的有检查访问的异常 (类) |
辅助对象
(C++17) |
nullopt_t 类型对象 (常量) |
原位构造标签 (类模板) |
推导指引
示例
运行此代码
#include <string> #include <functional> #include <iostream> #include <optional> // optional 可用作可能失败的工厂的返回类型 std::optional<std::string> create(bool b) { if(b) return "Godzilla"; else return {}; } // 能用 std::nullopt 创建任何(空的) std::optional auto create2(bool b) { return b ? std::optional<std::string>{"Godzilla"} : std::nullopt; } // std::reference_wrapper 可用于返回引用 auto create_ref(bool b) { static std::string value = "Godzilla"; return b ? std::optional<std::reference_wrapper<std::string>>{value} : std::nullopt; } int main() { std::cout << "create(false) returned " << create(false).value_or("empty") << '\n'; // 返回 optional 的工厂函数可用作 while 和 if 的条件 if (auto str = create2(true)) { std::cout << "create2(true) returned " << *str << '\n'; } if (auto str = create_ref(true)) { // 用 get() 访问 reference_wrapper 的值 std::cout << "create_ref(true) returned " << str->get() << '\n'; str->get() = "Mothra"; std::cout << "modifying it changed it to " << str->get() << '\n'; } }
输出:
create(false) returned empty create2(true) returned Godzilla create_ref(true) returned Godzilla modifying it changed it to Mothra
参阅
(C++17 起) |
类型安全的可辨识联合体 (类模板) |
(C++17 起) |
可保有任何可复制构造 (CopyConstructible) 类型的实例的对象。 (类) |