C++官网参考链接:https://cplusplus.com/reference/cstdlib/quick_exit/
函数
<cstdlib>
quick_exit
C11
_Noreturn void quick_exit (int status);
C++11
[[noreturn]] void quick_exit (int status) noexcept;
调用使用at_quick_exit注册的所有函数后,通过将控制权返回给宿主环境来正常终止进程。
不执行额外的清理任务:不调用对象析构函数。但是是否关闭和/或刷新C流,以及是否删除使用tmpfile打开的文件取决于特定的系统或库实现。
如果status为0或EXIT_SUCCESS,则向宿主环境返回一个成功的终止状态。
如果status为EXIT_FAILURE,则向宿主环境返回不成功的终止状态。
否则,返回的状态取决于系统和库实现。
如果一个程序调用了exit和quick_exit,或者调用quick_exit不止一次,就会导致未定义的行为。
形参
status
状态码。
如果这是0或EXIT_SUCCESS,则表示成功。
如果是EXIT_FAILURE,则表示失败。
返回值
没有返回值(函数从不返回)。
用例
/* quick_exit example */
#include <stdio.h> /* puts */
#include <stdlib.h> /* at_quick_exit, quick_exit, EXIT_SUCCESS */
void fnQExit (void)
{
puts ("Quick exit function.");
}
int main ()
{
at_quick_exit (fnQExit);
puts ("Main function: Beginning");
quick_exit (EXIT_SUCCESS);
puts ("Main function: End"); // never executed
return 0;
}
输出:
官网参考答案:
Main function: Beginning Quick exit function.
数据竞争
同时多次调用此函数是没有效果的。
在调用此函数之前未完成的at_quick_exit调用可能不会成功(取决于特定的库实现)。
异常(C++)
无抛出保证:此函数从不抛出异常。
如果向at_quick_exit注册的任何函数抛出异常,则自动调用terminate。