ICLRPolicyManager::SetActionOnTimeout 方法

指定公共语言运行时 (CLR) 在指定操作超时应执行的策略操作。

HRESULT SetActionOnTimeout (
    [in] EClrOperation operation,
    [in] EPolicyAction action
);

参数

  • operation
    [in] EClrOperation 的值之一,指示要为其指定超时操作的操作。 下列值是受支持的:

    • OPR_AppDomainUnload

    • OPR_ProcessExit

    • OPR_ThreadRudeAbortInCriticalRegion

    • OPR_ThreadRudeAbortInNonCriticalRegion

  • action
    [in] EPolicyAction 的值之一,指示要在操作超时时采取的策略操作。

返回值

HRESULT

说明

S_OK

SetActionOnTimeout 已成功返回。

HOST_E_CLRNOTAVAILABLE

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

HOST_E_TIMEOUT

调用超时。

HOST_E_NOT_OWNER

调用方不拥有锁。

HOST_E_ABANDONED

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

E_FAIL

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

E_INVALIDARG

无法为指定的 operation 设置超时,或为 operation 提供了无效值。

备注

超时值可以是 CLR 设置的默认超时,或者是宿主在对 ICLRPolicyManager::SetTimeout 方法的调用中指定的值。

并非所有的策略操作值都可被指定为 CLR 操作的超时行为。 SetActionOnTimeout 通常只用于提升行为。 例如,宿主可以指定将线程终止转变为强制线程终止,但是不能指定相反的转变。 下表描述了有效 operation 值的有效 action 值。

operation 的值

action 的有效值

OPR_ThreadRudeAbortInNonCriticalRegion

OPR_ThreadRudeAbortInCriticalRegion

  • eRudeAbortThread

  • eUnloadAppDomain

  • eRudeUnloadAppDomain

  • eExitProcess

  • eFastExitProcess

  • eRudeExitProcess

  • eDisableRuntime

OPR_AppDomainUnload

  • eUnloadAppDomain

  • eRudeUnloadAppDomain

  • eExitProcess

  • eFastExitProcess

  • eRudeExitProcess

  • eDisableRuntime

OPR_ProcessExit

  • eExitProcess

  • eFastExitProcess

  • eRudeExitProcess

  • eDisableRuntime

要求

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

**头文件:**MSCorEE.h

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

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

请参见

参考

EClrOperation 枚举

EPolicyAction 枚举

ICLRControl 接口

ICLRPolicyManager 接口