Namespaces
Variants

std:: _Exit

From cppreference.net
Utilities library
定义于头文件 <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 ,则返回表示 未成功 终止的实现定义状态。其他情况下返回实现定义的状态值。

独立实现必须提供 std::_Exit

(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