次の方法で共有


_CrtSetDbgFlag

_crtDbgFlag フラグの状態を取得または変更して、デバッグ ヒープ マネージャーの割り当て動作を制御します (デバッグ バージョンのみ)。

int _CrtSetDbgFlag(     int newFlag  );

パラメーター

  • newFlag
    _crtDbgFlag の新しい状態。

戻り値

_crtDbgFlag の以前の状態を返します。

解説

_CrtSetDbgFlag 関数を使用すると、アプリケーションは _crtDbgFlag フラグのビット フィールドを変更することによって、デバッグ ヒープ マネージャーがメモリ割り当てを追跡する方法を制御できます。 ビットを設定する (オンにする) ことによって、アプリケーションはデバッグ ヒープ マネージャーに特別なデバッグ操作の実行を指示できます。たとえば、アプリケーション終了時にメモリ リークを確認し、リークを発見した場合に報告したり、解放されたメモリ ブロックをヒープのリンク リストに残すように指定してメモリ不足状況をシミュレーションしたり、すべての割り当て要求時に各メモリ ブロックを検査してヒープの整合性を検証したりすることができます。 _DEBUG が未定義の場合、_CrtSetDbgFlag の呼び出しはプリプロセスで削除されます。

次の表は、_crtDbgFlag のビット フィールドと、その動作の説明の一覧です。 ビットを設定すると、診断出力が増加し、プログラムの実行速度が低下するため、これらのビットは既定では設定されていません (オフになっています)。 これらのビット フィールドの詳細については、「ヒープの状態をレポートする関数」を参照してください。

ビット フィールド

既定値

説明

_CRTDBG_ALLOC_MEM_DF

ON

オン: デバッグ ヒープ割り当てと、_CLIENT_BLOCK などのメモリ ブロック型識別子の使用を有効にします。 オフ: ヒープのリンク リストに新しい割り当てを追加しますが、ブロックの型を _IGNORE_BLOCK に設定します。

ヒープ頻度チェック マクロのいずれかと組み合わせることもできます。

_CRTDBG_CHECK_ALWAYS_DF

OFF

オン: 割り当て要求および解放要求のたびに _CrtCheckMemory を呼び出します。 オフ: _CrtCheckMemory を明示的に呼び出す必要があります。

このフラグが設定されている場合、ヒープ頻度チェック マクロは効果がありません。

_CRTDBG_CHECK_CRT_DF

OFF

オン: リーク検出およびメモリ状態比較の操作に _CRT_BLOCK 型を含めます。 オフ: ランタイム ライブラリによって内部的に使用されるメモリは、これらの操作では無視されます。

ヒープ頻度チェック マクロのいずれかと組み合わせることもできます。

_CRTDBG_DELAY_FREE_MEM_DF

OFF

オン: 解放されたメモリ ブロックをヒープのリンク リストに保持し、それらに _FREE_BLOCK 型を割り当てて、バイト値 0xDD を設定します。 オフ: 解放されたブロックをヒープのリンク リストに保持しません。

ヒープ頻度チェック マクロのいずれかと組み合わせることもできます。

_CRTDBG_LEAK_CHECK_DF

OFF

オン: _CrtDumpMemoryLeaks を呼び出すことによってプログラムの終了時に自動リーク チェックを実行し、アプリケーションが割り当てたすべてのメモリを解放できなかった場合はエラー レポートを生成します。 オフ: プログラムの終了時に自動的なリーク チェックを行いません。

ヒープ頻度チェック マクロのいずれかと組み合わせることもできます。

ヒープ頻度チェック マクロ

C ランタイム ライブラリがデバッグ ヒープ (_CrtCheckMemory) の検証を実行する頻度を、mallocreallocfree、および _msize の呼び出しの数に基づいて指定できます。

_CrtSetDbgFlag は、newFlag パラメーターの上位 16 ビットで値を調べます。 指定された値は、_CrtCheckMemory の呼び出し間の mallocreallocfree、および _msize の呼び出し数です。 この目的のために、4 つの定義済みマクロが用意されています。

マクロ

_CrtCheckMemory の呼び出し間の malloc、realloc、free、および _msize の呼び出し数

_CRTDBG_CHECK_EVERY_16_DF

16

_CRTDBG_CHECK_EVERY_128_DF

128

_CRTDBG_CHECK_EVERY_1024_DF

1024

_CRTDBG_CHECK_DEFAULT_DF

0 (既定では、ヒープ チェックなし)

既定では、mallocreallocfree、および _msize を 1,024 回呼び出すごとに、_CrtCheckMemory が 1 回呼び出されます。

たとえば、次のコードでは、16 個の mallocreallocfree、および _msize 操作ごとのヒープ チェックを指定できます。

#include <crtdbg.h>
int main( )
{
int tmp;

// Get the current bits
tmp = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);

// Clear the upper 16 bits and OR in the desired freqency
tmp = (tmp & 0x0000FFFF) | _CRTDBG_CHECK_EVERY_16_DF;

// Set the new bits
_CrtSetDbgFlag(tmp);
}

newFlag パラメーターの上位 16 ビットは、_CRTDBG_CHECK_ALWAYS_DF が指定されている場合は無視されます。 この場合、mallocreallocfree、および _msize を呼び出すたびに _CrtCheckMemory が呼び出されます。

newFlag は _crtDbgFlag に適用する新しい状態であり、各ビット フィールドの値の組み合わせです。

これらのビット フィールドを変更して、フラグの新しい状態を作成するには

  1. newFlag を _CRTDBG_REPORT_FLAG と同じにして _CrtSetDbgFlag を呼び出して現在の _crtDbgFlag の状態を取得し、返された値を一時変数に格納します。

  2. この一時変数と、対応するビットマスクとの OR 演算を行い、ビットをオンにします。ビットマスクは、アプリケーション コードの中ではマニフェスト定数で表されています。

  3. 一時変数と、適切なビットマスクのビットごとの NOT との AND 演算を行い、他のビットをオフにします。

  4. newFlag を一時変数に格納されている値と同じにして _CrtSetDbgFlag を呼び出すことによって、_crtDbgFlag の新しい状態を設定します。

次のコードは、解放されたメモリ ブロックをヒープのリンク リストに保持することでメモリ不足の状態をシミュレートし、割り当て要求のたびに _CrtCheckMemory が呼び出されないようにする方法を示しています。

// Get the current state of the flag
// and store it in a temporary variable
int tmpFlag = _CrtSetDbgFlag( _CRTDBG_REPORT_FLAG );

// Turn On (OR) - Keep freed memory blocks in the
// heap's linked list and mark them as freed
tmpFlag |= _CRTDBG_DELAY_FREE_MEM_DF;

// Turn Off (AND) - prevent _CrtCheckMemory from
// being called at every allocation request
tmpFlag &= ~_CRTDBG_CHECK_ALWAYS_DF;

// Set the new state for the flag
_CrtSetDbgFlag( tmpFlag );

メモリ管理とデバッグ ヒープの概要については、「CRT デバッグ ヒープ」を参照してください。

_CrtSetDbgFlag 関数でフラグを無効にするには、変数と、ビットマスクのビットごとの NOTAND 演算する必要があります。

newFlag が有効な値でない場合は、「パラメーターの検証」に説明されているように、この関数によって無効なパラメーター ハンドラーが呼び出されます。 実行の継続が許可された場合、この関数は errno を EINVAL に設定し、_crtDbgFlag の以前の状態を返します。

必要条件

ルーチン

必須ヘッダー

_CrtSetDbgFlag

<crtdbg.h>

互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。

ライブラリ

C ランタイム ライブラリのデバッグ バージョンのみ。

使用例

// crt_crtsetdflag.c
// compile with: /c -D_DEBUG /MTd -Od -Zi -W3 /link -verbose:lib /debug
/*
 * This program concentrates on allocating and freeing memory
 * blocks to test the functionality of the _crtDbgFlag flag..
 */

#include <string.h>
#include <malloc.h>
#include <crtdbg.h>

int main( )
{
        char *p1, *p2;
        int tmpDbgFlag;

        _CrtSetReportMode( _CRT_ERROR, _CRTDBG_MODE_FILE );
        _CrtSetReportFile( _CRT_ERROR, _CRTDBG_FILE_STDERR );
        /*
         * Set the debug-heap flag to keep freed blocks in the
         * heap's linked list - This will allow us to catch any
         * inadvertent use of freed memory
         */
        tmpDbgFlag = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);
        tmpDbgFlag |= _CRTDBG_DELAY_FREE_MEM_DF;
        tmpDbgFlag |= _CRTDBG_LEAK_CHECK_DF;
        _CrtSetDbgFlag(tmpDbgFlag);

        /*
         * Allocate 2 memory blocks and store a string in each
         */
        p1 = malloc( 34 );
        p2 = malloc( 38 );
        strcpy_s( p1, 34, "p1 points to a Normal allocation block" );
        strcpy_s( p2, 38, "p2 points to a Client allocation block" );

        /*
         * Free both memory blocks
         */
        free( p2 );
        free( p1 );

        /*
         * Set the debug-heap flag to no longer keep freed blocks in the
         * heap's linked list and turn on Debug type allocations (CLIENT)
         */
        tmpDbgFlag = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);
        tmpDbgFlag |= _CRTDBG_ALLOC_MEM_DF;
        tmpDbgFlag &= ~_CRTDBG_DELAY_FREE_MEM_DF;
        _CrtSetDbgFlag(tmpDbgFlag);

        /*
         * Explicitly call _malloc_dbg to obtain the filename and 
         * line number of our allocation request and also so we can 
         * allocate CLIENT type blocks specifically for tracking
         */
        p1 = _malloc_dbg( 40, _NORMAL_BLOCK, __FILE__, __LINE__ );
        p2 = _malloc_dbg( 40, _CLIENT_BLOCK, __FILE__, __LINE__ );
        strcpy_s( p1, 40, "p1 points to a Normal allocation block" );
        strcpy_s( p2, 40, "p2 points to a Client allocation block" );

        /*
         * _free_dbg must be called to free the CLIENT block
         */
        _free_dbg( p2, _CLIENT_BLOCK );
        free( p1 );

        /*
         * Allocate p1 again and then exit - this will leave unfreed
         * memory on the heap
         */
        p1 = malloc( 10 );
}

同等の .NET Framework 関数

該当なし。標準 C 関数を呼び出すには、PInvoke を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。

参照

関連項目

デバッグ ルーチン

_crtDbgFlag

_CrtCheckMemory