ICorProfilerInfo4::GetCodeInfo3 メソッド
指定した関数の JIT 再コンパイル バージョンに関連付けられているネイティブ コードの範囲を取得します。
構文
HRESULT GetCodeInfo3(
[in] FunctionID functionID,
[in] ReJITID reJitId,
[in] ULONG32 cCodeInfos,
[out] ULONG32 *pcCodeInfos,
[out, size_is(cCodeInfos), length_is(*pcCodeInfos)]
COR_PRF_CODE_INFO codeInfos[]);
パラメーター
functionID
[in] ネイティブ コードが関連付けられている関数の ID。
reJitId
[in] JIT 再コンパイルされた関数のID。
cCodeInfos
[in] codeInfos
配列のサイズ。
pcCodeInfos
[out] 使用できる COR_PRF_CODE_INFO 構造体の総数へのポインター。
codeInfos
[out] 呼び出し元が提供したバッファー。 メソッドから制御が戻った後で、それぞれがネイティブ コードのブロックを記述する COR_PRF_CODE_INFO
の構造体の配列が含まれます。
解説
GetCodeInfo3
メソッドは GetCodeInfo2 に似ていますが、指定した IP アドレスを含む関数の JIT 再コンパイルされた ID を取得します。
Note
GetCodeInfo3
はガベージ コレクションをトリガーできますが、GetCodeInfo2 はガベージ コレクションをトリガーしません。 詳細については、CORPROF_E_UNSUPPORTED_CALL_SEQUENCE HRESULT を参照してください。
エクステントは共通中間言語 (CIL) オフセットの昇順に並べ替えられます。
GetCodeInfo3
から制御が戻ったら、codeInfos
バッファーのサイズが十分で、すべての COR_PRF_CODE_INFO 構造体を格納できることを確認する必要があります。 これを行うには、cCodeInfos
の値を cchName
パラメーターの値と比較します。 COR_PRF_CODE_INFO 構造体のサイズによって除算された cCodeInfos
が pcCodeInfos
より小さい場合は、codeInfos
バッファーの割り当てを増やし、cCodeInfos
を新しい大きいサイズに更新した後、GetCodeInfo3
を再度呼び出します。
別の方法として、最初に GetCodeInfo3
を長さゼロの codeInfos
バッファーで呼び出して、適切なバッファーのサイズを取得します。 その後 codeInfos
バッファーのサイズを、pcCodeInfos
で返された値と、COR_PRF_CODE_INFO 構造体のサイズを乗算した値に設定し、GetCodeInfo3
を再度呼び出します。
必要条件
:「システム要件」を参照してください。
ヘッダー : CorProf.idl、CorProf.h
ライブラリ: CorGuids.lib
.NET Framework のバージョン: 4.5 以降で使用可能
関連項目
.NET