命名空间
变体
操作

std::set_new_handler

来自 cppreference.com
< cpp‎ | memory‎ | new
 
 
实用程序库
语言支持
类型支持 (基本类型,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)

 
动态内存管理
未初始化内存算法
受约束的未初始化内存算法
分配器
垃圾回收支持
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)



 
 
定义在头文件 <new>
std::new_handler set_new_handler( std::new_handler new_p ) throw();
(直到 C++11)
std::new_handler set_new_handler( std::new_handler new_p ) noexcept;
(自 C++11 起)

使 new_p 成为新的全局 new 处理程序函数,并返回先前安装的 new 处理程序。

new 处理程序 函数是当内存分配尝试失败时由 分配函数 调用的函数。它的预期用途是以下三件事之一

1) 提供更多可用内存,
2) 终止程序(例如,通过调用 std::terminate),
3) 抛出类型为 std::bad_alloc 或从 std::bad_alloc 派生的异常。

默认实现抛出 std::bad_alloc。用户可以安装自己的 new 处理程序,它可能提供与默认处理程序不同的行为。

如果 new 处理程序 返回,分配函数将重复先前失败的分配尝试,如果分配再次失败,则再次调用 new 处理程序。要结束循环,new 处理程序 可以调用 std::set_new_handler(nullptr):如果在分配尝试失败后,分配函数发现 std::get_new_handler 返回一个空指针值,它将抛出 std::bad_alloc

在程序启动时,new 处理程序 是一个空指针。

此函数是线程安全的。对 std::set_new_handler 的每次调用都 (见 std::memory_order)随后的 std::set_new_handlerstd::get_new_handler 调用同步。

(自 C++11 起)

内容

[编辑] 参数

new_p - 指向类型为 std::new_handler 的函数的指针,或空指针

[编辑] 返回值

先前安装的 new 处理程序,如果未安装任何处理程序,则为空指针值。

[编辑] 示例

#include <iostream>
#include <new>
 
void handler()
{
    std::cout << "Memory allocation failed, terminating\n";
    std::set_new_handler(nullptr);
}
 
int main()
{
    std::set_new_handler(handler);
    try
    {
        while (true)
        {
            new int[1000'000'000ul]();
        }
    }
    catch (const std::bad_alloc& e)
    {
        std::cout << e.what() << '\n';
    }
}

可能的输出

Memory allocation failed, terminating
std::bad_alloc

[编辑] 另请参阅

分配函数
(函数) [编辑]
获取当前 new 处理程序
(函数) [编辑]
new 处理程序的函数指针类型
(typedef) [编辑]
内存分配失败时抛出的异常
(类) [编辑]