汇编中try catch的实现
来源:互联网 发布:制作app软件多少钱 编辑:程序博客网 时间:2024/06/05 15:09
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;平台定义
.386
.Model Flat,StdCall
Option CaseMap:None
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;文件包含
include windows.inc
include kernel32.inc
include user32.inc
includelib user32.lib
includelib kernel32.lib
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;常量定义
.const
szMsg db "异常发生位置%08x,异常代码:%08x,标志:%08x",0
szSEH1 db "如果发生异常,该对话框将显示",0
szCaption1 db "显示对话框",0
szSEH2 db "如果异常发生,该对话框不应该显示",0
szCaption2 db "永远无法显示的对话框",0
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;代码段定义
.code
;自定义的SEH异常处理过程
_Handler proc _lpExceptionRecord,_lpSEH,_lpContext,_lpDispatcherContext
;局部变量的定义
local @szBuffer[256]:byte
pushad
mov esi,_lpExceptionRecord;
mov edi,_lpContext;
assume esi:ptr EXCEPTION_RECORD,edi:ptr CONTEXT;
;格式化字符串
invoke wsprintf,addr @szBuffer,addr szMsg,[edi].regEip,[esi].ExceptionCode,[esi].ExceptionFlags;
;显示异常信息
invoke MessageBox,NULL,addr @szBuffer,NULL,MB_OK;
mov [edi].regEip,offset SEH1;接下来要进行的操作,类似于重定向操作
assume esi:nothing,edi:nothing
popad
mov eax,ExceptionContinueExecution;
ret
_Handler endp;
SEH:
assume fs:nothing
push offset _Handler;注册异常处理程序
push fs:[0];该参数并不重要,他应该指向的是下一个SEH处理历程,在这里,我们只是需要一个数据来进行占位,表示该数据之后的地址指向了异常处理过程
mov fs:[0],esp;//栈顶指向EXCEPTION_REGISTRATION
xor eax,eax;
mov DWORD ptr[eax],0;这里产生异常读取位置异常,因为要读取[0000]位置的数据
SHE2:
invoke MessageBox,NULL,addr szSEH2,addr szCaption2,MB_OK;
SEH1:
invoke MessageBox,NULL,addr szSEH1,addr szCaption1,MB_OK;
pop fs:[0]
pop eax
invoke ExitProcess,0
end SEH;表明程序的入口点
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;平台定义
.386
.Model Flat,StdCall
Option CaseMap:None
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;文件包含
include windows.inc
include kernel32.inc
include user32.inc
includelib user32.lib
includelib kernel32.lib
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;常量定义
.const
szMsg db "异常发生位置%08x,异常代码:%08x,标志:%08x",0
szSEH1 db "如果发生异常,该对话框将显示",0
szCaption1 db "显示对话框",0
szSEH2 db "如果异常发生,该对话框不应该显示",0
szCaption2 db "永远无法显示的对话框",0
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;代码段定义
.code
;自定义的SEH异常处理过程
_Handler proc _lpExceptionRecord,_lpSEH,_lpContext,_lpDispatcherContext
;局部变量的定义
local @szBuffer[256]:byte
pushad
mov esi,_lpExceptionRecord;
mov edi,_lpContext;
assume esi:ptr EXCEPTION_RECORD,edi:ptr CONTEXT;
;格式化字符串
invoke wsprintf,addr @szBuffer,addr szMsg,[edi].regEip,[esi].ExceptionCode,[esi].ExceptionFlags;
;显示异常信息
invoke MessageBox,NULL,addr @szBuffer,NULL,MB_OK;
mov [edi].regEip,offset SEH1;接下来要进行的操作,类似于重定向操作
assume esi:nothing,edi:nothing
popad
mov eax,ExceptionContinueExecution;
ret
_Handler endp;
SEH:
assume fs:nothing
push offset _Handler;注册异常处理程序
push fs:[0];该参数并不重要,他应该指向的是下一个SEH处理历程,在这里,我们只是需要一个数据来进行占位,表示该数据之后的地址指向了异常处理过程
mov fs:[0],esp;//栈顶指向EXCEPTION_REGISTRATION
xor eax,eax;
mov DWORD ptr[eax],0;这里产生异常读取位置异常,因为要读取[0000]位置的数据
SHE2:
invoke MessageBox,NULL,addr szSEH2,addr szCaption2,MB_OK;
SEH1:
invoke MessageBox,NULL,addr szSEH1,addr szCaption1,MB_OK;
pop fs:[0]
pop eax
invoke ExitProcess,0
end SEH;表明程序的入口点
;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
- 汇编中try catch的实现
- 关于C++: try...catch...的汇编实现&相关讨论,FS
- try/catch的实现原理
- try/catch的实现原理
- try/catch的实现原理
- try/catch的实现原理
- C++ 的 try throw catch 反汇编方法
- C++ 的 try throw catch 反汇编方法 收藏
- try/catch的实现原理 ---转
- try throw catch 的实现原理
- flash中try catch的不同编译
- c++ 中 try catch 的一些
- c++中try catch的用法
- java中try 与catch的使用
- java中try 与catch的使用
- java中try catch的用法
- java中try 与catch的使用
- try-catch-finally中return的执行情况
- 标准C获取当前系统时间
- 学程序要学会整理总结
- F28335_ECAP使用
- 两种设置控件背景颜色的方法
- Java栈与堆
- 汇编中try catch的实现
- 数据结构-图-Java实现:有向图 图存储(邻接矩阵),最小生成树,广度深度遍历,图的连通性,最短路径
- Golomb 编码
- CSS之Position详解
- TQ2440 LED驱动程序
- 关于无法保存Visual Studio自定义布局的问题
- Xcode如何查看内存中的数据
- getopt_long()函数作用
- SIM卡读卡器的研究与设计