std::_Exit
来自cppreference.com
在标头 <cstdlib> 定义 | ||
[[noreturn]]void _Exit(int exit_code )noexcept; | (C++11 起) | |
导致发生正常程序终止,而不清理资源。
不调用拥有自动、线程局域和静态存储期对象的析构函数。不调用传递给 std::at_quick_exit() 或 std::atexit() 的函数。是否关闭打开的资源,例如文件,是实现定义的。
若 exit_code
为 0 或 EXIT_SUCCESS,则向宿主环境返回一个指示成功终止的实现定义状态。若 exit_code
为 EXIT_FAILURE,则返回指示不成功终止的实现定义状态。其他情况下返回实现定义的状态值。
要求独立实现提供 | (C++23 起) |
目录 |
[编辑]参数
exit_code | - | 程序的退出状态 |
[编辑]返回值
(无)
[编辑]注解
尽管 _Exit
从 C++23 起要求为独立,标准不要求它在独立的 C 实现中可用。
[编辑]示例
运行此代码
#include <iostream> class Static {public: ~Static(){std::cout<<"静态析构\n";}}; class Local {public: ~Local(){std::cout<<"局部析构\n";}}; Static static_variable;// 此对象的析构函数将*不*被调用 void atexit_handler(){std::cout<<"atexit 处理函数\n";} int main(){ Local local_variable;// 将*不*调用析构函数 // 将*不*调用处理函数constint result =std::atexit(atexit_handler); if(result !=0){std::cerr<<"atexit 注册失败\n";returnEXIT_FAILURE;} std::cout<<"test"<<std::endl;// 此处需要由 std::endl 冲洗,否则不会打印内容 std::_Exit(EXIT_FAILURE);}
输出:
test
[编辑]参阅
导致非正常的程序终止(不进行清理) (函数) | |
导致正常的程序终止并进行清理 (函数) | |
_Exit 的 C 文档 |