std::_Exit
来自cppreference.com
<tbody>
</tbody>
| 在标头 <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; // 将*不*调用析构函数
// 将*不*调用处理函数
const int result = std::atexit(atexit_handler);
if (result != 0)
{
std::cerr << "atexit 注册失败\n";
return EXIT_FAILURE;
}
std::cout << "test" << std::endl; // 此处需要由 std::endl 冲洗,否则不会打印内容
std::_Exit(EXIT_FAILURE);
}
输出:
test
参阅
| 导致非正常的程序终止(不进行清理) (函数) | |
| 导致正常的程序终止并进行清理 (函数) | |
_Exit 的 C 文档
| |