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 处理函数 #" << N << std::endl; // 冲洗是有意的
}
 
void at_exit_handler()
{
    std::cout << "at_exit 处理函数\n";
}
 
int main()
{
    if (std::at_quick_exit(quick_exit_handler<1>) ||
        std::at_quick_exit(quick_exit_handler<2>))
    {
        std::cerr << "注册失败\n";
        return EXIT_FAILURE;
    }
 
    std::atexit(at_exit_handler); // 不会调用处理函数
 
    struct R { ~R() { std::cout << "析构函数\n"; } } resource;
 
    /*...*/
 
    std::quick_exit(EXIT_SUCCESS);
 
    std::cout << "这条语句不可达...\n";
}

输出:

quick_exit 处理函数 #2
quick_exit 处理函数 #1

参阅

导致非正常的程序终止(不进行清理)
(函数)
导致正常的程序终止并进行清理
(函数)
注册将于调用 std::exit() 时被调用的函数
(函数)
注册将于调用 quick_exit 时被调用的函数
(函数)