名稱空間
變體
操作

std::set_new_handler

來自 cppreference.com
< cpp‎ | 記憶體‎ | new
 
 
 
記憶體管理庫
(僅作說明*)
未初始化記憶體演算法
(C++17)
(C++17)
(C++17)
受約束的未初始化
記憶體演算法
C 庫

分配器
記憶體資源
垃圾回收支援
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
未初始化儲存
(直到 C++20*)
(直到 C++20*)
顯式生命週期管理
 
 
定義於標頭檔案 <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-handler 函式,並返回先前安裝的 new-handler。

new-handler 函式是在每次記憶體分配嘗試失敗時,由分配函式呼叫的函式。其預期目的有三:

1) 提供更多記憶體,
2) 終止程式(例如透過呼叫 std::terminate),
3) 丟擲型別為 std::bad_alloc 或派生自 std::bad_alloc 的異常。

預設實現丟擲 std::bad_alloc。使用者可以安裝自己的 new-handler,它可能提供與預設行為不同的行為。

如果 new-handler 返回,則分配函式會重複先前失敗的分配嘗試,如果分配再次失敗,則再次呼叫 new-handler。要結束迴圈,new-handler 可以呼叫 std::set_new_handler(nullptr):如果分配失敗後,分配函式發現 std::get_new_handler 返回一個空指標值,它將丟擲 std::bad_alloc

在程式啟動時,new-handler 是一個空指標。

此函式是執行緒安全的。每次呼叫 std::set_new_handler 都與(參見 std::memory_order)後續的 std::set_new_handlerstd::get_new_handler 呼叫同步。

(C++11 起)

目錄

[編輯] 引數

new_p - 指向型別為 std::new_handler 的函式的指標,或空指標

[編輯] 返回值

先前安裝的 new-handler,如果未安裝則為空指標值。

[編輯] 示例

#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 處理函式的函式指標型別
(型別定義) [編輯]
記憶體分配失敗時丟擲的異常
(類) [編輯]