std::quick_exit
来自cppreference.com
<tbody>
</tbody>
| 在标头 <cstdlib> 定义
|
||
[[noreturn]] void quick_exit( int exit_code ) noexcept; |
(C++11 起) | |
导致发生正常程序终止,而不完全清理资源。
以注册顺序的逆序调用传递给 std::at_quick_exit 的函数。若有异常试图从这些函数中传播出来,则调用 std::terminate。调用注册的函数后,调用 std::_Exit(exit_code)。
不调用传递给 std::atexit 的函数。
参数
| exit_code | - | 程序的退出状态 |
返回值
(无)
示例
运行此代码
#include <cstdlib>
#include <iostream>
template<int N>
void quick_exit_handler()
{
std::cout << "quick_exit 处理函数 #" << N << std::endl; // 冲洗是有意的
}
void at_exit_handler()
{
std::cout << "at_exit 处理函数\n";
}
int main()
{
if (std::at_quick_exit(quick_exit_handler<1>) ||
std::at_quick_exit(quick_exit_handler<2>))
{
std::cerr << "注册失败\n";
return EXIT_FAILURE;
}
std::atexit(at_exit_handler); // 不会调用处理函数
struct R { ~R() { std::cout << "析构函数\n"; } } resource;
/*...*/
std::quick_exit(EXIT_SUCCESS);
std::cout << "这条语句不可达...\n";
}
输出:
quick_exit 处理函数 #2
quick_exit 处理函数 #1
参阅
| 导致非正常的程序终止(不进行清理) (函数) | |
| 导致正常的程序终止并进行清理 (函数) | |
| 注册将于调用 std::exit() 时被调用的函数 (函数) | |
(C++11) |
注册将于调用 quick_exit 时被调用的函数 (函数) |
quick_exit 的 C 文档
| |