RaiseException()

RaiseException

目录


展开

展开
该函数是用来抛出一个调用线程时发生的异常.

语法

void WINAPI RaiseException(
__in DWORD dwExceptionCode,
__in DWORD dwExceptionFlags,
__in DWORD nNumberOfArguments,
__in const ULONG_PTR *lpArguments );
dwExceptionCode
一个在 抛出异常时应用程序定义的异常代码。 该筛选 表达式异常处理程序的异常处理程序块可以使用 GetExceptionCode函数获得它的值。
请注意,系统会在显示信息之前清除dwExceptionCode参数的第28位,该位是一个系统保留的异常位,仅供系统自身使用。
dwExceptionFlags
异常标志。
这可以赋值为零,表示一个可持续异常,或者使用EXCEPTION_NONCONTINUABLE标志来表示一个不可持续的异常。
发生不可持续的异常后,任何企图继续执行的行为将导致触EXCEPTION_NONCONTINUABLE_EXCEPTION异常。
nNumberOfArguments
表示lpArguments参数 数组中的参数个数。 这个值不能超过EXCEPTION_MAXIMUM_PARAMETERS。
如果lpArguments为NULL ,则忽略此参数。
lpArguments
一个参数 数组。 这个参数可以是NULL。
这些参数可以包含任何应用程序所定义的数据,而这些数据需要传递给 异常处理程序的筛选 表达式

返回值

这个函数没有返回值。

备注

该函数启用一个进程并使用 结构化异常处理来处理私有的,软件生成的和应用程序定义的异常。
一个 异常处理程序在引发异常并导致异常调度的时候需要经过以下步骤的处理:
1.如果有调试器,系统首先尝试通知进程的调试器。
2.如果这一进程不被调试,或者相关的调试器不处理异常,系统将尝试通过搜索发生异常的线程的 堆栈来定位一个基于帧的 异常处理程序。 系统首先会搜索当前 栈帧,然后继续向后搜索栈帧。
3.如果没有找到基于帧的 异常处理程序,或没有基于帧的异常处理程序处理该异常,系统将会第二次尝试通知进程的调试器。
4.如果该进程仍未被调试,或者相关的调试器不处理异常,系统以异常类型为基础提供默认的处理程序。 对于大多数异常,默认动作是调用ExitProcess函数。

要求

最低支持的客户端
Windows 2000专业版
最低支持的服务器
Windows 2000服务器
头文件
WINBASE.H中(包括Windows.h中)
库文件
Kernel32.lib
DLL
Kernel32.dll

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值