std::set_new_handler
From 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-ハンドラ関数に設定し、以前にインストールされていた new-ハンドラを返します。
new-ハンドラ関数は、メモリ割り当ての試みが失敗するたびに、割り当て関数によって呼び出される関数です。その意図された目的は、次の3つのうちのいずれかです。
1) より多くのメモリを利用可能にする。
2) プログラムを終了する(例: std::terminate を呼び出す)。
デフォルトの実装は std::bad_alloc をスローします。ユーザーは、デフォルトとは異なる動作を提供する独自の *new-ハンドラ* をインストールできます。
new-ハンドラが返された場合、割り当て関数は以前失敗した割り当ての試みを繰り返します。再度割り当てが失敗した場合、再び *new-ハンドラ* を呼び出します。ループを終了するために、*new-ハンドラ* は std::set_new_handler(nullptr) を呼び出すことができます。割り当ての試みが失敗した後、割り当て関数が std::get_new_handler が null ポインタ値を返すことを発見した場合、std::bad_alloc をスローします。
プログラム起動時、*new-ハンドラ* は null ポインタです。
|
この関数はスレッドセーフです。 |
(C++11以降) |
目次 |
[編集] パラメータ
| new_p | - | std::new_handler 型の関数へのポインタ、または null ポインタ。 |
[編集] 戻り値
以前にインストールされていた new-ハンドラ。インストールされていなかった場合は null ポインタ値。
[編集] 例
このコードを実行
#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ハンドラの関数ポインタ型 (typedef) | |
| メモリ割り当てが失敗したときにスローされる例外 (クラス) |