IHostMAlloc::DebugAlloc メソッド
ホストに対して、指定した量のメモリをヒープから割り当て、さらにメモリが割り当てられた場所を追跡するように要求します。
HRESULT DebugAlloc (
[in] SIZE_T cbSize,
[in] EMemoryCriticalLevel dwCriticalLevel,
[in] char* pszFileName,
[in] int iLineNo,
[out] void** ppMem
);
パラメーター
cbSize
[入力] 現在のメモリの割り当て要求のサイズ (バイト単位)。dwCriticalLevel
[入力] 割り当てエラーの影響を示す EMemoryCriticalLevel 値のいずれか。pszFileName
[入力] デバッグ対象の実行可能なコード ファイル。iLineNo
[入力] 割り当てが要求された pszFileName 内の行番号。ppMem
[出力] 割り当てられたメモリへのポインター。要求を完了できなかった場合は null。
戻り値
HRESULT |
説明 |
---|---|
S_OK |
DebugAlloc が正常に終了しました。 |
HOST_E_CLRNOTAVAILABLE |
CLR がプロセスに読み込まれていません。または、CLR がマネージ コードを実行できない状態か、呼び出しを正常に処理できない状態にあります。 |
HOST_E_TIMEOUT |
呼び出しがタイムアウトしました。 |
HOST_E_NOT_OWNER |
呼び出し元がロックを所有していません。 |
HOST_E_ABANDONED |
ブロックされたスレッドまたはファイバーが待機しているイベントがキャンセルされました。 |
E_FAIL |
未知の重大エラーが発生しました。 メソッドから E_FAIL が返される場合、プロセス内で CLR を使用することはできません。 ホスト メソッドへの後続の呼び出しは、HOST_E_CLRNOTAVAILABLE を返します。 |
E_OUTOFMEMORY |
メモリ不足のため、割り当て要求を完了できませんでした。 |
解説
CLR は IHostMemoryManager::CreateMalloc メソッドを呼び出して、IHostMalloc インスタンスへのインターフェイス ポインターを取得します。 DebugAlloc により、ランタイムはデバッグ中に使用するコード ファイル情報を取得できます。
必要条件
プラットフォーム: 「.NET Framework システム要件」を参照
ヘッダー : MSCorEE.h
ライブラリ: MSCorEE.dll にリソースとして格納されていること
.NET Framework のバージョン: 4、3.5 SP1、3.5、3.0 SP1、3.0、2.0 SP1、2.0