CorDebugChainReason 枚举

指示一个或多个调用链启动原因。

typedef enum CorDebugChainReason {
    CHAIN_NONE              = 0x000,
    CHAIN_CLASS_INIT        = 0x001,
    CHAIN_EXCEPTION_FILTER  = 0x002,
    CHAIN_SECURITY          = 0x004,
    CHAIN_CONTEXT_POLICY    = 0x008,
    CHAIN_INTERCEPTION      = 0x010,
    CHAIN_PROCESS_START     = 0x020,
    CHAIN_THREAD_START      = 0x040,
    CHAIN_ENTER_MANAGED     = 0x080,
    CHAIN_ENTER_UNMANAGED   = 0x100,
    CHAIN_DEBUGGER_EVAL     = 0x200,
    CHAIN_CONTEXT_SWITCH    = 0x400,
    CHAIN_FUNC_EVAL         = 0x800
} CorDebugChainReason;

成员

成员

说明

CHAIN_NONE

未启动任何调用链。

CHAIN_CLASS_INIT

构造函数启动了该链。

CHAIN_EXCEPTION_FILTER

异常筛选器启动了该链。

CHAIN_SECURITY

强制实施安全性的代码启动了该链。

CHAIN_CONTEXT_POLICY

上下文策略启动了该链。

CHAIN_INTERCEPTION

未使用。

CHAIN_PROCESS_START

未使用。

CHAIN_THREAD_START

开始执行线程时启动了该链。

CHAIN_ENTER_MANAGED

进入托管代码时启动了该链。

CHAIN_ENTER_UNMANAGED

进入非托管代码时启动了该链。

CHAIN_DEBUGGER_EVAL

未使用。

CHAIN_CONTEXT_SWITCH

未使用。

CHAIN_FUNC_EVAL

函数求值启动了该链。

备注

使用 ICorDebugChain::GetReason 方法来确定调用链的启动原因。

要求

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

头文件: CorDebug.idl、CorDebug.h

**库:**CorGuids.lib

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

请参见

其他资源

调试枚举