ICLRPolicyManager::SetActionOnFailure 方法

更新:2007 年 11 月

指定在发生指定故障时公共语言运行库 (CLR) 应执行的策略操作。

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

参数

  • failure
    [in] EClrFailure 的值之一,指示对其采取操作的故障类型。

  • action
    [in] EPolicyAction 的值之一,指示要在故障发生时采取的操作。FAIL_FatalRuntime 的 failure 值的唯一支持的值为 eRudeExitProcess。当发生错误时,CLR 默认将被禁用。对于值为 FAIL_CriticalResource 或 FAIL_NonCriticalResource 的 failure,支持下列值:

    • eNoAction

    • eThrowException

    • eAbortThread

    • eRudeAbortThread

    • eUnloadAppDomain

    • eRudeUnloadAppDomain

    • eExitProcess

    • eRudeExitProcess

    • eDisableRuntime

返回值

HRESULT

说明

S_OK

SetActionOnFailure 成功返回。

HOST_E_CLRNOTAVAILABLE

CLR 尚未加载到进程中或者处于无法运行托管代码或成功处理调用的状态。

HOST_E_TIMEOUT

调用超时。

HOST_E_NOT_OWNER

调用方不拥有锁。

HOST_E_ABANDONED

事件在被阻止的线程或纤程正在等待它时被取消。

E_FAIL

发生了未知的灾难性故障。在某方法返回 E_FAIL 后,CLR 便无法再在进程中使用。对宿主方法的后续调用都将返回 HOST_E_CLRNOTAVAILABLE。

E_INVALIDARG

无法为指定的操作设置策略操作,或者为该操作指定了无效的策略操作。

备注

默认情况下,CLR 在无法分配诸如内存等资源时引发异常。SetActionOnFailure 允许宿主通过指定要在发生故障时采取的策略操作来重写此行为。

要求

**平台:**请参见 .NET Framework 系统要求

**头文件:**MSCorEE.idl

**库:**作为一项资源包含在 MSCorEE.dll 中

**.NET Framework 版本:**3.5 SP1、3.5、3.0 SP1、3.0、2.0 SP1、2.0

请参见

参考

EClrFailure

EPolicyAction

ICLRControl

ICLRPolicyManager