SetUnhandledExceptionFilter处理未捕获异常

2023-11-05

一、        

        首先看下百度上的对此函数的解释。

    设置异常捕获函数.

  当异常没有处理的时候,系统就会调用SetUnhandledExceptionFilter所设置异常处理函数.

  例如一些程序在出错的时候,会向用户报告说程序那出错就是利用这个.例如QQ..

二、

  异常处理中的一部分

  当发生异常时,比如内存访问违例时,CPU硬件会发现此问题,并产生一个异常(你可以把它理解为中断)然后CPU会把代码流程切换到异常处理服务程。  

    操作系统异常处理服务例程会查看当前进程是否处于调试状态。如果是,则通知调试器发生了异常,如果不是则操作系统会查看当前线程是否安装了的异常帧链(FS[0]),如果安装了SEH(try.... catch....),则调用SEH,并根据返回结果决定是否全局展开活局部展开。如果异常链中所有的SEH都没有处理此异常,而且此进程还处于调试状态,则操作系统会再次通知调试器发生异常(二次异常)。如果还没人处理,则调用操作系统的默认异常处理代码UnhandledExceptionHandler,不过操作系统允许你Hook这个函数,就是通过SetUnhandledExceptionFilter函数来设置。大部分异常通过此种方法都能捕获,不过栈溢出、覆盖的有可能捕获不到。

  大部分保护壳都采用异常处理技术,跳出正常的代码指令流程,来迷惑Cracker

   三、

  说的有点粗略。下面根据自己的理解阐述下。

   SetUnhandledExceptionFilter,根据函数的名字能看出是设置异常处理函数,其实如果程序没设置异常处理函数,程序会调用默认的处理函数处理异常,然后程序终止,一般情况下就弹出个对话框。

如何设置自己的异常处理函数?

LPTOP_LEVEL_EXCEPTION_FILTER SetUnhandledExceptionFilter(
LPTOP_LEVEL_EXCEPTION_FILTER
lpTopLevelExceptionFilter
);

参数是一个函数指针,定义如下

LONG UnhandledExceptionFilter(
STRUCT _EXCEPTION_POINTERS
*ExceptionInfo
);

函数类型

ExceptionInfo 是对异常描述的一个结构体

typedef struct _EXCEPTION_POINTERS {
PEXCEPTION_RECORD ExceptionRecord;
PCONTEXT ContextRecord;
} EXCEPTION_POINTERS, *PEXCEPTION_POINTERS; 


 

异常捕获函数有三种返回值

EXCEPTION_EXECUTE_HANDLER:表明异常处理完毕,程序可以退出

EXCEPTION_CONTINUE_EXECUTION:忽略此异常,从异常点继续运行。如果此时再发生异常,还会调用异常处理函数

EXCEPTION_CONTINUE_SEARCH:异常没被识别,交由上一级处理函数处理;

SetUnhandledExceptionFilter返回值,如果为0,表明此时没有附加额外的处理函数(除默认的处理函数),如果非空,则存放到当前顶层的处理函数地址

需要注意的是,SetUnhandledExceptionFilter设置的异常处理函数为全局的处理函数,是异常发生后,最后一次处理异常的机会。如果程序被调试器附加。调试器将优先于SetUnhandledExceptionFilter设置的异常处理函数处理异常。

C++自定义的try{}Catch{}比较。这是C++自定义的异常处理过程,利用SEH来处理发生的异常,如果异常发生,又出现在try{}Catch{}中 将得到优先处理。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SetUnhandledExceptionFilter处理未捕获异常 的相关文章

  • 如何初始化结构体指针数组?

    是否可以初始化结构体指针数组 就像是 struct country t countries United States of America America England Europe Ethiopia Africa 我想这样做是为了获取
  • “struct X typedef”与“typedef struct X”的含义是什么?

    我在现有代码库中有以下 工作 代码 在 C 和 C 之间共享的包含文件中使用 在 MSVC 2010 和 Windows DDK 上编译 struct X USHORT x typedef X PX And enum MY ENUM enu
  • 最佳实践:从属性中抛出异常

    什么时候适合从属性 getter 或 setter 中抛出异常 什么时候不合适呢 为什么 关于这个主题的外部文档的链接会很有帮助 谷歌搜索结果出奇的少 Microsoft 在以下位置提供了有关如何设计属性的建议 http msdn micr
  • Python Tornado 中的异常处理

    我正在尝试处理发生的异常AsyncClient fetch这样 from tornado httpclient import AsyncHTTPClient from tornado httpclient import HTTPReques
  • 在 C# 中通过 C DLL 使用数组和指针

    我对 C 非常陌生 上周才开始学习 我有一个用 C 编写的自定义 DLL 具有以下函数 DLLIMPORT void test function double test 我想要做的是从 C 获取数组 test 的指针 因此 如果在 DLL
  • 在 MVVM 中哪里可以捕获异常?

    我的视图模型类有一个连接到服务的方法 不确定这是否是一个好的实践 或者视图模型是否应该是严格的属性和属性更改机制 当然 我想在连接或断开连接时处理任何可能的 WCF 异常 让我们使用未找到端点作为示例 考虑到这是一个我想引起用户注意的异常
  • 熊猫:有条件的groupby

    我有数据框 ID used at active seconds subdomain visiting category 123 2016 02 05 19 39 21 2 yandex ru 2 Computers 123 2016 02
  • 如何正确关闭保存文件句柄

    我正在开发一个与 USB 设备通信的 C 项目 我打开连接 DllImport Kernel32 dll SetLastError true static extern Microsoft Win32 SafeHandles SafeFil
  • Android ListView addHeaderView() XML 中定义的预定义视图出现 nullPointerException

    尝试使用addHeaderView and addFooterView for a ListView 如果我尝试使用在 XML 中为页眉或页脚预定义的视图 则会出现空指针异常 但是 如果我使用代码动态创建一个视图 它工作得很好 This d
  • C 结构体信息隐藏(不透明指针)

    我目前对 C 结构信息隐藏的概念有点困惑 这道题的背景是一个嵌入式c项目 对OOP的了解几乎为零 到目前为止 我总是在相应模块的头文件中声明我的 typedef 结构 因此每个想要使用该结构的模块都知道该结构类型 但经过 MISRA C 检
  • 初始化嵌套匿名结构

    我有一个 json 作为 fields time id status customerId additionalDetail pageInfo start 0 rows 1000 我想将我的结构编组到上面的 json 并创建如下结构 typ
  • 从 []byte 到 char*

    我想包装一个 C 函数 它需要一个char 指向非空字节缓冲区 的第一个元素 我正在尝试使用 CGo 将其包装在 Go 函数中 以便我可以将其传递给 byte 但我不知道如何进行转换 C 函数签名的简化版本是 void foo char c
  • 处理异步并行任务的多个异常

    Problem 多个任务并行运行 所有任务 没有任务或其中任何任务都可能抛出异常 当所有任务完成后 必须报告所有可能发生的异常 通过日志 电子邮件 控制台输出 等等 预期行为 我可以通过 linq 使用异步 lambda 构建所有任务 然后
  • 捕获 SQLAlchemy 异常

    我可以使用什么捕获 SQLAlechmy 异常的上层异常 gt gt gt from sqlalchemy import exc gt gt gt dir exc ArgumentError CircularDependencyError
  • C 或 C++ 中未初始化的指针有用途吗?

    在其中一篇评论中这个问题 https stackoverflow com questions 1910832 c why arent pointers initialized with null by default 有人指出默认初始化 C
  • Android ListView数组索引过滤后越界

    我认为这是专家的问题 我接到电话getView with positon 出界来自ListView数据列表 当我使用适配器过滤器时会发生这种情况 过滤器publishResults 方法使用小于原始列表的过滤列表填充数据 当新的过滤列表时似
  • 为什么结构中“[0]byte”的位置很重要?

    0 byte在golang中不应该占用任何内存空间 但这两个结构体的大小不同 type bar2 struct A int 0 byte type bar3 struct 0 byte A int 那么为什么这个位置 0 byte这里重要吗
  • 如何单独捕获这些异常?

    我正在编写一个与 Quickbooks 交互的 Python 程序 连接到 Quickbooks 时 根据问题的不同 我可能会遇到以下两个常见异常之一 pywintypes com error 2147352567 Exception oc
  • 我需要一个支持高效随机访问和 O(k) 插入和删除的容器

    我再次尝试问同样的问题question https stackoverflow com questions 3808708 delete parts of a dynamic array and grow other 但我最终提出了一个不同
  • 指向指针的指针与普通指针

    指针的作用是保存特定变量的地址 那么下面代码的内存结构应该是这样的 int a 5 int b a 内存地址 值一个 0x000002 5b 0x000010 0x000002 好的 那么假设现在我要保存指针 b的地址 那么我们一般定义一个

随机推荐

  • 区块链入门学习笔记(一)

    比特币的原理和运行机制 1 比特币产生的动机 以物易物 实物货币 黄金 符号货币 纸币 中央系统虚拟货币 分布式虚拟货币 中本聪 2 基础设施搭建 1 账簿公开机制 账簿不记录余额 只记录交易 账簿由私有改为公开 2 身份与签名机制 公钥加
  • 软件架构概

    一 软件架构的概念 1 组成派认为 1 软件系统的架构将系统描述为计算机组件及组件之间的交互 其中 计算机组件是泛指 计算机组件可以进一步细分为处理组件 数据组件 连接组件等 组件可以指子系统 框架 模块 类等不同粒度的软件单元 2 组成派
  • 分布式操作系统在服务器上吗,什么是分布式操作系统?

    什么叫分布式操作系统 要想掌握的盆友看一下以下几点吧 分布式操作系统归属于分布式手机软件系统在其中的一部分 关键承担部门管理分布式解决系统資源和操纵分布式程序执行 分布式操作系统是传统式操作系统观念的转型 就例如 传统式营销方式和新起的互联
  • 【Docker】离线安装、普通用户执行docker命令、镜像归档打tar包,及加载tar包镜像

    离线安装 1 下载docker官方离线包 在有外网的环境中先把离线包下载下来 安装包官方地址 https download docker com linux static stable x86 64 2 上传离线包到服务器 使用scp命令或
  • Java 变量的作用域

    在Java中 变量的作用域分为四个级别 类级 类级变量又叫全局级变量或静态变量 需要使用static关键字修饰 类级变量在类定义后就已经存在 占用内存空间 可以通过类名来访问 不需要实例化 对象实例级 对象实例级变量就是成员变量 实例化后才
  • 如何做网络通信的项目?

    http blog csdn net clarkcc1988 article details 8825106 JAVA TCP SOCKET MINA 什么是Socket 网络上的两个程序通过一个双向的通讯连接实现数据的交换 这个双向链路的
  • Servlet注解和可插拔性(第八篇)

    文章目录 8 1 注解和可插拔性 8 1 1 WebServlet 注解 8 1 2 WebFilter web过滤器 8 1 3 WebInitParam 8 1 4 WebListener 8 1 5 MultipartConfig 8
  • CTFHUB SQL注入——时间盲注 附自己写的脚本

    介绍 时间盲注和上一篇布尔盲注一样都是盲注 都需要借助length ascii substr这些神奇的函数来猜测各项信息 它们的差别是猜测成功的依据 布尔盲注的话如果查询有结果 一般会有一个success flag 比如在上一题里就会返回q
  • CCF CSP 202303-1 田地丈量

    首先理解题意 题目意思很明确 就是找到重叠矩形的面积和 第一想法是想使用一个标志数组对每一个矩形所覆盖的地方进行标志 最后遍历选择的矩形面 对已经标志过的点计数即可 但是由于这里输入坐标的最大值可以达到10 4 而我们遍历矩形需要嵌套for
  • 使用 Docker 搭建适用于 HomeLab 的书签导航

    在使用新私有化部署的书签导航应用一个月之后 我们来聊聊书签导航工具 以及介绍如何使用 Docker 在几分钟之内部署属于你自己的书签导航应用 写在前面 我目前使用的书签导航工具的界面是这样的 马赛克掉了一部分链接内容 作为一个使用了十多年
  • 【微信小程序/云开发bug解决方案合集】持续更新中(最新23-3-29)

    一 小程序 1 chooseMessageFile没反应 在电脑端测试是调不出来微信聊天界面的 需要在真机调试中使用 2 pages kaifazhe kaifazhe does not have a method chooseExcel
  • 游戏引擎设计的技术及详解

    游戏引擎的那点事 这东西是个啥 功能 渲染器 渲染流程 物理引擎 粒子 流体 软体 物理 碰撞检测系统 音效 游戏音效 音效分类 按音效格式和制作方式分类 按功能分
  • CentOS 7下安装windows字体

    1 在日常生产中打开文件时发现中文乱码 考虑到编码或者是否有中文字体库 在CentOS 7中执行命令发现字体列表命令无效 上图发现字体库都没安装 接下来就会简单说一下CentOS 7 中安装字体库和中文字体 2 安装字体库 主要用到font
  • 自举电路原理分析

    原文来自公众号 工程师看海 自举电路字面意思是自己把自己抬起来的电路 是利用自举升压电容的升压电路 是电子电路中常见的电路之一 我们经常在IC外围器件中看到自举电容 比如下图同步降压转换器 BUCK 电路中 Cboot就是自举电容 为什么要
  • DataTables从入门到精通

    DataTables从入门到精通
  • ListView与适配器

    ListView与适配器 ListView是什么 ListView是一个以垂直方式在项目中显示视图的列表 即在一个窗口里可以滚动查看数据 比如说查看聊天记录 是一种不能实现确定视图中的内容的适配器视图 adapter view 数据和视图的
  • $nextTick实现原理详解

    vue中有一个较为特殊的API nextTick 根据官方文档的解释 它可以在DOM更新完毕之后执行一个回调 用法如下 修改数据 vm msg Hello DOM 还没有更新 Vue nextTick function DOM 更新了 复制
  • 5 个免费开源的 3D 建模/渲染工具。

    5 个开源 3D 建模 渲染工具 3八 2011 作者 riku 本文采用 CC BY NC SA 2 5协议授权 转载请注明 本文链接 5 个免费开源的 3D 建模 渲染工具 1 Art of Illusion 跨平台 支持 Window
  • 15000cd是多少流明_光通量(lm)发光强度(cd)照度单位(lux)之间的关系

    光通量 lm 发光强度 cd 照度单位 lux 之间的关系 光通量 lm 由于人眼对不同波长的电磁波具有不同的灵敏度 我们不能直接用光源的辐 射功率或辐射通量来衡量光能量 必须采用以人眼对光的感觉量为基准的单位 光通量来衡量 光通量的用符号
  • SetUnhandledExceptionFilter处理未捕获异常

    一 首先看下百度上的对此函数的解释 设置异常捕获函数 当异常没有处理的时候 系统就会调用SetUnhandledExceptionFilter所设置异常处理函数 例如一些程序在出错的时候 会向用户报告说程序那出错就是利用这个 例如QQ 二