命名空间
变体
操作

std::quick_exit

来自 cppreference.com
< cpp‎ | utility‎ | program
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库功能测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三方比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
 
在头文件 <cstdlib> 中定义
[[noreturn]] void quick_exit( int exit_code ) noexcept;
(自 C++11 起)

导致正常的程序终止,而不会完全清理资源。

传递给 std::at_quick_exit 的函数按注册的相反顺序调用。如果异常试图从任何函数传播出去,则会调用 std::terminate。在调用注册的函数后,会调用 std::_Exit(exit_code)

传递给 std::atexit 的函数不会被调用。

内容

[编辑] 参数

exit_code - 程序的退出状态

[编辑] 返回值

(无)

[编辑] 示例

#include <cstdlib>
#include <iostream>
 
template<int N>
void quick_exit_handler()
{
    std::cout << "quick_exit handler #" << N << std::endl; // flush is intended
}
 
void at_exit_handler()
{
    std::cout << "at_exit handler\n";
}
 
int main()
{
    if (std::at_quick_exit(quick_exit_handler<1>) ||
        std::at_quick_exit(quick_exit_handler<2>))
    {
        std::cerr << "Registration failed\n";
        return EXIT_FAILURE;
    }
 
    std::atexit(at_exit_handler); // the handler will not be called
 
    struct R { ~R() { std::cout << "destructor\n"; } } resource;
 
    /*...*/
 
    std::quick_exit(EXIT_SUCCESS);
 
    std::cout << "This statement is unreachable...\n";
}

输出

quick_exit handler #2
quick_exit handler #1

[编辑] 另请参阅

导致异常的程序终止(不进行清理)
(函数) [编辑]
导致正常的程序终止,并进行清理
(函数) [编辑]
注册一个在 std::exit() 调用时调用的函数
(函数) [编辑]
注册一个在 std::quick_exit 调用时调用的函数
(函数) [编辑]
C 文档quick_exit