ICLRPolicyManager::SetActionOnFailure メソッド

更新 : 2010 年 7 月

指定したエラーが発生したときに共通言語ランタイム (CLR) が実行するポリシー アクションを指定します。

HRESULT SetActionOnFailure (
    [in] EClrFailure   failure,
    [in] EPolicyAction action
);

パラメーター

  • failure
    [入力] アクションの実行につながるエラーの種類を示す EClrFailure 値のいずれか。

  • action
    [入力] エラーが発生したときに実行されるアクションを示す EPolicyAction 値のいずれか。 サポートされている値の一覧については、「解説」を参照してください。

戻り値

HRESULT

説明

S_OK

SetActionOnFailure が正常に終了しました。

HOST_E_CLRNOTAVAILABLE

CLR がプロセスに読み込まれていません。または、CLR がマネージ コードを実行できない状態か、呼び出しを正常に処理できない状態にあります。

HOST_E_TIMEOUT

呼び出しがタイムアウトしました。

HOST_E_NOT_OWNER

呼び出し元がロックを所有していません。

HOST_E_ABANDONED

ブロックされたスレッドまたはファイバーが待機しているイベントがキャンセルされました。

E_FAIL

未知の重大エラーが発生しました。 メソッドから E_FAIL が返された後は、プロセス内で CLR を使用することはできません。 ホスト メソッドへの後続の呼び出しで、HOST_E_CLRNOTAVAILABLE が返されます。

E_INVALIDARG

指定した操作にポリシー アクションを設定することはできません。または、操作に無効なポリシー アクションが指定されました。

解説

既定では、CLR は、メモリなどのリソースの割り当てに失敗すると例外をスローします。 SetActionOnFailure では、エラーの場合に実行するポリシー アクションを指定することによって、ホストがこの動作をオーバーライドできます。 サポートされる EClrFailure 値と EPolicyAction 値の組み合わせを次の表に示します (FAIL_ prefix は EClrFailure 値から省かれています)。

NonCriticalResource

CriticalResource

FatalRuntime

OrphanedLock

StackOverflow

AccessViolation

CodeContract

eNoAction

X

X

不可

eThrowException

X

X

不可

eAbortThread

X

X

不可

X

eRudeAbortThread

X

X

不可

X

eUnloadAppDomain

X

X

X

不可

X

eRudeUnloadAppDomain

X

X

X

X

不可

X

eExitProcess

X

X

X

X

不可

X

eFastExitProcess

X

X

X

X

不可

eRudeExitProcess

X

X

X

X

X

不可

eDisableRuntime

X

X

X

X

X

不可

必要条件

プラットフォーム: 「.NET Framework システム要件」を参照

ヘッダー : MSCorEE.h

ライブラリ: MSCorEE.dll にリソースとして格納されていること

.NET Framework のバージョン: 4、3.5 SP1、3.5、3.0 SP1、3.0、2.0 SP1、2.0

参照

参照

EClrFailure 列挙型

EPolicyAction 列挙型

ICLRControl インターフェイス

ICLRPolicyManager インターフェイス

履歴の変更

日付

履歴

理由

2010 年 7 月

許可される EClrFailure 値と EPolicyAction 値の組み合わせを修正、それらを表に挿入。

コンテンツ バグ修正