当前位置: 首页 > 工具软件 > Quick-Scope > 使用案例 >

C++ Reference: Standard C++ Library reference: C Library: cstdlib: quick_exit

雷硕
2023-12-01

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

 类似资料: