std:: _Exit
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Program termination | |||||||||||||||||||||
|
|||||||||||||||||||||
| Unreachable control flow | |||||||||||||||||||||
|
(C++23)
|
|||||||||||||||||||||
| Communicating with the environment | |||||||||||||||||||||
| Signals | |||||||||||||||||||||
| Signal types | |||||||||||||||||||||
| Non-local jumps | |||||||||||||||||||||
| Types | |||||||||||||||||||||
|
定义于头文件
<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
,则返回表示
未成功
终止的实现定义状态。其他情况下返回实现定义的状态值。
|
独立实现必须提供
|
(since C++23) |
目录 |
参数
| exit_code | - | 程序的退出状态 |
返回值
(无)
注释
尽管自 C++23 起要求
_Exit
在独立环境中可用,但 C 语言的独立实现并不要求提供该函数。
示例
#include <iostream> class Static { public: ~Static() { std::cout << "Static dtor\n"; } }; class Local { public: ~Local() { std::cout << "Local dtor\n"; } }; Static static_variable; // 此对象的析构函数将*不会*被调用 void atexit_handler() { std::cout << "atexit handler\n"; } int main() { Local local_variable; // 此对象的析构函数将*不会*被调用 // 处理函数将*不会*被调用 const int result = std::atexit(atexit_handler); if (result != 0) { std::cerr << "atexit registration failed\n"; return EXIT_FAILURE; } std::cout << "test" << std::endl; // 由 std::endl 执行的刷新操作 // 必须在此处,否则不会有任何输出 std::_Exit(EXIT_FAILURE); }
输出:
test
参阅
|
导致程序异常终止(不进行清理操作)
(函数) |
|
|
导致程序正常终止并执行清理操作
(函数) |
|
|
C 文档
关于
_Exit
|
|