std::quick_exit
来自cppreference.com
在标头 <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";returnEXIT_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 文档 |