名前空間
変種
操作

std::set_new_handler

From 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++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-ハンドラ関数に設定し、以前にインストールされていた new-ハンドラを返します。

new-ハンドラ関数は、メモリ割り当ての試みが失敗するたびに、割り当て関数によって呼び出される関数です。その意図された目的は、次の3つのうちのいずれかです。

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 が null ポインタ値を返すことを発見した場合、std::bad_alloc をスローします。

プログラム起動時、*new-ハンドラ* は null ポインタです。

この関数はスレッドセーフです。std::set_new_handler へのすべての呼び出しは、後続の std::set_new_handler および std::get_new_handler の呼び出しと *同期* します(std::memory_order を参照)。

(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

[編集] 関連項目

メモリ割り当て関数
(関数) [編集]
現在のnewハンドラを取得する
(関数) [編集]
newハンドラの関数ポインタ型
(typedef) [編集]
メモリ割り当てが失敗したときにスローされる例外
(クラス) [編集]
English 日本語 中文(简体) 中文(繁體)