C++ 参考手册
- C++11
- C++14
- C++17
- C++20
- C++ 编译器支持情况表
- 独立与宿主实现
- C++ 语言
- C++ 关键词
- 预处理器
- C++ 标准库头文件
- 具名要求
- 功能特性测试 (C++20)
- 工具库
- 类型支持(基本类型、RTTI、类型特性)
- 概念库 (C++20)
- 错误处理
- 动态内存管理
- 日期和时间工具
- 字符串库
- 容器库
- 迭代器库
- 范围库 (C++20)
- 算法库
- 数值库
- 输入/输出库
- 文件系统库
- 本地化库
- 正则表达式库
- 原子操作库
- 线程支持库
- 实验性 C++ 特性
- C++ 标准库扩展
- std::experimental::pmr::resource_adaptor
- std::experimental::invocation_type, std::experimental::raw_invocation_type
- C++ 标准库扩展,版本 2
- std::experimental::propagate_const
- std::experimental::ostream_joiner
- std::experimental::randint
- std::experimental::observer_ptr
- std::experimental::is_detected, std::experimental::detected_t, std::experimental::detected_or
- C++ 标准库扩展,版本 3
- std::experimental::scope_exit
- std::experimental::scope_fail
- std::experimental::scope_fail<EF>::scope_fail
- std::experimental::scope_fail<EF>::~scope_fail
- std::experimental::scope_fail<EF>::release
- std::experimental::scope_fail 的推导指引
- 并行扩展
- 并行扩展,版本 2
- std::experimental::sample
- std::experimental::to_array
- std::experimental::source_location
- std::experimental::not_fn
- std::experimental::future
- std::experimental::shared_future
- std::experimental::scope_success
- std::experimental::unique_resource
- 并发扩展
- 制约与概念
- 范围扩展
- std::experimental::function
- std::experimental::nonesuch
- std::experimental::reseed
- std::experimental::shuffle
- std::experimental::when_all
- std::experimental::barrier
- std::experimental::latch
- std::experimental::make_array
- 数学特殊函数
- 文件系统库
- std::experimental::erased_type
- std::experimental::when_any
- std::experimental::make_ready_future
- std::experimental::make_exceptional_future
- std::experimental::flex_barrier
- 注释
- 有用的资源
- 索引
- std 符号索引
- 协程支持 (C++20)
- C++ 关键词
位置:首页 > C++ 参考手册 >实验性 C++ 特性 > std::experimental::scope_fail
std::experimental::scope_fail
定义于头文件 <experimental/scope>
|
||
template<class EF> class scope_fail; |
(库基础 TS v3) | |
类模板 scope_fail
是通用的作用域防护,有意使它在经由异常退出作用域时调用其退出函数。
scope_fail
非可复制构造 (CopyConstructible) 、可复制赋值 (CopyAssignable) 或可移动赋值 (MoveAssignable) ,然而若 EF
满足某些要求则它可能为可移动构造 (MoveConstructible) ,这允许包装 scope_fail
到另一对象中。
scope_fail
可为活跃,即在析构时调用其退出函数,或为不活跃,即在析构时不做任何事。在从退出函数构造后 scope_fail
为活跃。
scope_fail
能因手动或自动(由移动构造函数)在它上调用 release() 后变得不活跃。亦可由从另一不活跃的 scope_fail
初始化获得不活跃的 scope_fail
。一旦 scope_fail
不活跃,则它不能再次变得活跃。
一个 scope_fail
等效地保有一个 EF
与一个指示它是否活跃的 bool 标签,还有一个用于检测是否在栈回溯期间调用析构函数的未捕捉异常的计数器。
模板形参
EF | - | 退出函数的类型 |
类型要求 | ||
-EF 可为:
| ||
-以无参数调用 std::remove_reference_t<EF> 的左值必须为良构。 |
成员函数
构造新的 scope_fail (公开成员函数) | |
在经由异常退出作用域时调用退出函数,若 scope_fail 为活跃,然后销毁 scope_fail (公开成员函数) | |
operator= [被删除] |
scope_fail 不可赋值 (公开成员函数) |
修改器 | |
使 scope_fail 不活跃 (公开成员函数) |
推导指引
注解
构造拥有动态存储期的 scope_fail
可能导致不期待的行为。
从创建于另一线程的 scope_fail
构造 scope_fail
亦可能导致不期待的行为,因为可能在析构期间比较从另一线程获得的未捕捉异常计数。
示例
本节未完成 原因:暂无示例 |
参阅
包装函数对象并在退出作用域时调用 (类模板) | |
包装函数对象并在正常退出作用域时调用 (类模板) | |
(C++11) |
unique_ptr 的默认删除器 (类模板) |