IHostMAlloc::DebugAlloc メソッド
指定されたメモリ量をヒープから割り当て、さらにメモリが割り当てられた場所を追跡することをホストに要求します。
構文
HRESULT DebugAlloc (
[in] SIZE_T cbSize,
[in] EMemoryCriticalLevel dwCriticalLevel,
[in] char* pszFileName,
[in] int iLineNo,
[out] void** ppMem
);
パラメーター
cbSize
[in] 現在のメモリ割り当て要求のサイズ (バイト単位)。
dwCriticalLevel
[入力] 割り当て失敗の影響を示す EMemoryCriticalLevel 値の 1 つ。
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
では、デバッグ中に使用する目的でコード ファイル情報を取得することがランタイムに許可されます。
必要条件
:「システム要件」を参照してください。
ヘッダー: MSCorEE.h
ライブラリ: MSCorEE.dll にリソースとして含まれます
.NET Framework のバージョン: 2.0 以降で使用可能
関連項目
GitHub で Microsoft と共同作業する
このコンテンツのソースは GitHub にあります。そこで、issue や pull request を作成および確認することもできます。 詳細については、共同作成者ガイドを参照してください。
.NET