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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_40186813

你的能量无可限量。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值