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
参照
参照
履歴の変更
日付 |
履歴 |
理由 |
---|---|---|
2010 年 7 月 |
許可される EClrFailure 値と EPolicyAction 値の組み合わせを修正、それらを表に挿入。 |
コンテンツ バグ修正 |