std::bad_expected_access

来自cppreference.com
< cpp‎ | utility‎ | expected
 
 
工具库
语言支持
类型支持(基本类型、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)

 
 
在标头 <expected> 定义
template< class E >
class bad_expected_access : public std::bad_expected_access<void>
(1) (C++23 起)
template<>
class bad_expected_access<void> : public std::exception
(2) (C++23 起)
1) 定义了一种类型,当访问一个包含非预期值的 expected 对象时,由 std::expected::value 抛出。bad_expected_access<E> 存储了非预期值的副本。
2) bad_expected_access<void> 是所有其他 bad_expected_access 特化的基类。

主模板的成员

(构造函数)
构造 bad_expected_access 对象
(公开成员函数)
error
返回储存的值
(公开成员函数)
what
返回用于解释的字符串
(公开成员函数)

std::bad_expected_access::bad_expected_access

explicit bad_expected_access( E e );

构造一个新的 bad_expected_access<E> 对象。用 std::move(e) 初始化存储的值。

std::bad_expected_access::error

const E& error() const & noexcept;

E& error() & noexcept;
const E&& error() const && noexcept;

E&& error() && noexcept;

返回到储存的值的引用。

std::bad_expected_access::what

const char* what() const noexcept override;

返回用于解释的字符串。

参数

(无)

返回值

指向一个包含解释性信息的空终止字符串。该字符串可以转换和显示为 std::wstring。该指针保证在至少从其获得的异常对象被销毁之前,或者在异常对象上调用一个非 const 成员函数(例如复制赋值运算符)之前,是有效的。

注解

实现允许但是不需要重写 what()

bad_expected_access<void> 特化的成员

(构造函数)
构造 bad_expected_access<void> 对象
(受保护成员函数)
(析构函数)
销毁 bad_expected_access<void> 对象
(受保护成员函数)
operator=
替换 bad_expected_access<void> 对象
(受保护成员函数)
what
返回用于解释的字符串
(公开成员函数)

bad_expected_access<void> 特化的成员函数是受保护的,它们只能在派生类中调用。

示例