std::set_new_handler
來自 cppreference.com
定義於標頭檔案 <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),
預設實現丟擲 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 是一個空指標。
此函式是執行緒安全的。每次呼叫 |
(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
[編輯] 參閱
分配函式 (函式) | |
(C++11) |
獲取當前的 new 處理函式 (函式) |
new 處理函式的函式指標型別 (型別定義) | |
記憶體分配失敗時丟擲的異常 (類) |