次の方法で共有


IDebugControl::Evaluate メソッド (dbgeng.h)

Evaluate メソッドは式を評価し、結果を返します。

構文

HRESULT Evaluate(
  [in]            PCSTR        Expression,
  [in]            ULONG        DesiredType,
  [out]           PDEBUG_VALUE Value,
  [out, optional] PULONG       RemainderIndex
);

パラメーター

[in] Expression

評価する式を指定します。

[in] DesiredType

目的の戻り値の型を指定します。 使用可能な値については、DEBUG_VALUEで説明します。戻り値の型が式の自然な型である必要があることを示すDEBUG_VALUE_INVALIDの追加。

[out] Value

式の値を受け取ります。

[out, optional] RemainderIndex

評価で使用されない式の最初の文字のインデックスを受け取ります。 RemainderIndex が NULL 場合、この情報は返されません。

戻り値

このメソッドは、他のエラー値を返す場合もあります。 詳細については 戻り値の を参照してください。

リターン コード 形容
S_OK
メソッドが成功しました。
E_FAIL
式の評価中にエラーが発生しました。 たとえば、構文エラー、未定義の変数、0 除算の例外が発生しました。

備考

式は、現在の 式エバリュエーターによって評価されます。 エンジンには複数の式エバリュエーターが含まれています。それぞれ異なる構文がサポートされています。 現在の式エバリュエーターは、SetExpressionSyntaxを使用して選択できます。

使用できる式エバリュエーターとその構文の詳細については、「数値式構文を参照してください。

式の評価中にエラーが発生し、E_FAILが返された場合は、RemainderIndex 変数を使用して、式内でエラーが発生した場所をほぼ特定できます。

必要条件

要件 価値
ターゲット プラットフォーム デスクトップ
ヘッダー dbgeng.h (Dbgeng.h を含む)

関連項目

GetExpressionSyntax

IDebugControl

IDebugControl2

IDebugControl3

SetExpressionSyntax

SetExpressionSyntaxByName