实验二 汇编语言动态调试程序Debug的使用.docx
- 文档编号:2144632
- 上传时间:2022-10-27
- 格式:DOCX
- 页数:13
- 大小:27.25KB
实验二 汇编语言动态调试程序Debug的使用.docx
《实验二 汇编语言动态调试程序Debug的使用.docx》由会员分享,可在线阅读,更多相关《实验二 汇编语言动态调试程序Debug的使用.docx(13页珍藏版)》请在冰豆网上搜索。
实验二汇编语言动态调试程序Debug的使用
实验二Debug的使用(基础与验证型)
一、实验要求和目的
熟练掌握动态调试程序DEBUG的使用;
二、软硬件环境
1、硬件环境:
微机CPU486以上,500MB以上硬盘,32M以上内存;
2、软件环境:
装有MASM5.0、Debug、LINK、EDIT、CREF.EXE和EXR2BIN.EXE等应用程序。
三、实验涉及的主要知识单元
通过编辑、汇编和连接后的程序是可以执行的程序。
但是,一个程序特别是比较复杂的程序不能保证没有一点错误。
因此,在投入正式运行前必须进行调试,以检查程序的正确性。
调试程序Debug就是用来调试汇编语言程序的一种工具。
Debug的主要功能有显示和修改寄存器及内存单元的内容;按指定地址启动并运行程序;设置断点使程序分段运行,以便检查程序运行过程中的中间结果或确定程序出错的位置;反汇编被调试程序,它将一个可执行文件中的指令机器码反汇编成助记符指令并同时给出指令所在的内存地址;单条追踪或多条追踪被调试程序,它可以逐条指令执行或几条指令执行被调试程序,每执行一条(或几条)指令后,Debug程序将中断程序的运行并提供有关结果信息;汇编一段程序,在Debug的汇编命令下可以直接输入助记符指令,并将其汇编成可运行程序段。
此外,Debug还可以将磁盘指定区的内容或一个文件装入到内存或将内存的信息写到磁盘上等等。
启动Debug程序:
在DOS状态下可以用下面的命令启动Debug程序:
DEBUG[路径文件名.扩展名]
Debug后面的文件名及路径是指被调试程序的文件名及路径,Debug后面的文件必须是程序的可执行文件,其扩展名可以是.EXE或.COM。
在此命令后,DOS将调试程序Debug调入内存,Debug接着将被调程序送入内存。
比如:
DEBUG123.EXE
调试程序Debug的主要命令如下:
(一)显示内存单元内容的命令D
格式
(1):
-D地址
从指定地址开始,显示128个字节的内容,每一行的左边显示段内偏移地址,接着显示16个单元的内容,最右边区域则显示这一行的16个单元所对应的可显示的字符。
若无可显示的字符,则用圆点(小数点)填充。
D命令中的地址可为段内偏移量,也可为段基址和段内偏移量两部分,中间用冒号隔开,如1680:
0110,即指段基址为1680H,段内偏移量为0110H。
Debug中所显示的数据均为十六进制数,且省去了后面的H标志。
格式
(2):
-D范围
将显示指定地址范围内的内存单元的内容,起始地址可由段基址及段内偏移量两个部分组成,中间用冒号“:
”隔开,也可以只指出段内偏移量,而此时的段基址在DS中。
这里所说的范围包含起始地址和结束地址。
比如–DDS:
10001020
将显示数据段偏移地址为1000H到1020H的内容。
(二)修改内存单元内容的命令E
格式
(1):
-E地址内容表
它的功能是用给定的内容表去代替所指定的内存单元的内容。
例如:
EDS:
011041‘CLOSE’41
该命令执行后,将用列表中的7个字符填入从DS:
0110到DS:
0116的7个存储单元中。
格式
(2):
E地址
它的功能是可以连续地逐个修改内存单元的内容。
当屏幕上显示指定单元的地址和内容之后,可采取下列办法:
①若指定单元的内容需要修改,则将新的内容的十六进制数输入,再按空格键,修改便告完成,然后显示下一个存储单元的地址及内容,若需要修改,可进行同样的操作。
若某一个单元的内容不需要修改,而操作又要进行下去,则可直接按空格键。
②若需要显示前一个单元的地址和内容,则输入连接号′-′,若要修改,则输入新的内容;若显示前一个单元的地址和内容仍要修改,则可进行同样的操作;若显示的内容不需要修改,则可直接按′-′键,使该操作由高地址向低地址单元连续不断地进行。
③按
(三)检查和修改寄存器内容的命令R
格式
(1):
R
此时将显示所有寄存器的内容和全部标志位的状态,以及现行CS:
IP所指的机器指令代码和反汇编符号。
格式
(2):
R寄存器名
该格式可用于检查和修改指定寄存器的内容。
若不修改其内容,可按
格式(3):
RF
该格式可用于显示标志和修改标志位状态。
当系统给出标志位状态后,可采取下列办法:
①若不需要修改任一标志位,可按
②若需要修改一个或多个标志位,可输入其相反的值。
各标志位之间可以无空格且与顺序无关,修改后按
由于标志位状态显示时,是用下列特殊符号表示的,因而修改时,只要输入规定的符号即可。
下面是标志名和状态符号的对照表:
标志名置位符号复位符号
溢出标志OF(是/否)OVNV
方向标志DF(减/增)DNUP
中断标志IF(允许/禁止)EIDI
符号标志SF(负/正)NGPL
零标志ZF(是/否)ZRNZ
辅助进位标志AF(是/否)ACNA
奇偶校验标志PF(偶/奇)PEPO
进位标志CF(是/否)CYNC
只有追踪标志TF,不能用指令直接修改。
例如:
输入RF命令,系统可能作出如下响应:
OVDNEINGZRACPECY-
若现在要修改奇偶、零、中断和溢出标志位,可在光标处输入:
PONZDINV
(四)运行程序命令G
格式:
G[=地址][地址[地址…]]
该命令可以在程序运行中设置断点。
它是Debug程序进行程序调试的主要命令之一。
示例:
-g001a则执行从当前cs:
ip至001a的指令,注意:
地址设置必须从指令的第一字节设起。
①第一个参数“=地址”规定了程序执行的起始地址,以CS内容作段地址,等号后面的地址只需给出地址偏移量。
此时,命令G与地址之间的等号不能省去。
如果在G命令执行前,已经设置了CS值和IP值,则也可以直接用G命令,从指定地址执行程序。
②格式中后面给出的地址是指断点地址,最多可设置10个断点。
当程序执行到一个断点时,就停下来,显示CPU各寄存器的内容和标志位的状态,以及下一条待执行的指令,被调试程序的所有断点全部被取消,并返回Debug。
③地址参数所指的单元,必须包含有有效的8088指令的第一个字节,否则将产生不可预料的结果。
④堆栈必须至少包含有6个可用字节,否则也将产生不可预料的结果。
⑤若断点地址只包括地址偏移量,则认为段地址在CS寄存器中。
(五)追踪命令T
格式
(1):
T[=地址]
该命令可以在指令执行中进行追踪,若略去地址,则从CS:
IP现行值执行。
每一次T命令都执行一条指令。
格式
(2):
T[=地址][值]
此时,它可对多条指令进行追踪,即在执行了由值所指定的若干条指令之后,停止执行并显示各寄存器的内容和各标志位,还指出下一条待执行的指令。
(六)汇编命令A
若在调试目标程序的过程中,要求改写或增添一段目标程序,则可以用A命令直接在Debug下实现。
格式:
A[地址]
该命令可以从指定地址开始,将输入的汇编语言语句立即汇编成机器代码,连续存放在内存单元中。
在程序输入完毕后,最后一行不输入内容,直接按回车键,即可返回DEBUG程序,还可用反汇编命令U对刚输入的内容进行反汇编,以验证输入的程序是否正确。
使用A命令应遵守以下规则:
①所有输入数值,均为十六进制数。
②前缀助记符,必须在相关指令的前面输入,可以在同一行,也可以在不同行输入。
③段超越助记符为CS:
、DS:
、ES:
、SS:
。
④远调用时的返回指令助记符用RETF。
⑤使用串操作指令时,助记符中必须注明是字节还是字传送。
⑥汇编语言能自动汇编短、近和远的转移及近和远的调用,也能由NEAR和FAR前缀来超越。
例如:
0110:
0600JMP602;短转移
0110:
0602JMPNEAR605;近转移
0110:
0605JMPFAR60A;远转移
第一条JMP指令中含有一个字节偏移量。
第二条JMP指令中含有两个字节偏移量。
第三条JMP指令中含有两个字节的偏移量及两个字节的段地址。
⑦当DEBUG不能确定某些操作数涉及的是字类型存储单元还是字节类型的存储单元时,在这种情况下,必须用前缀“WORDPTR”或“BYTEPTR”来加以说明。
例如:
NEGBYTEPTR[128]
DECWORD[SI]
⑧当Debug不能确定一个操作数是立即数还是存储单元的地址时,可以把地址放在方括号中。
⑨两个最常用的伪指令DB和DW可以在A命令中使用,用来直接把字节或字的值送入相应的存储单元。
例如:
DB2,5,3,4,′THISISANEXAMPLE′
DW6000,2000,7000,′BA′
⑩Debug支持所有形式的寄存器间接寻址命令。
例如:
ADDBX,74[BP+3][SI-5]
POP[BX+DI]
(七)反汇编命令U
格式
(1):
U地址
该命令从指定的地址开始,反汇编32个字节。
若略去指定地址,则以上一个U命令反汇编的最后一条指令地址的下一条指令地址作为起始地址;若没有用过U命令,则以由Debug初始化的段寄存器的值作段地址,以100作为地址偏移量。
格式
(2):
U范围这种格式的命令,可以对指定范围的内存单元进行反汇编,范围可以由起始地址、结束地址(只能包含地址偏移量)或起始地址及长度来指定。
其命令格式如:
U04BA:
1000108或U04BA:
0100L7
两者是等效的。
(八)输入命令I
格式:
I端口地址
该命令从指定端口输入一个字节并显示。
例如:
I2E8
CC
它表示所显示的是从02E8端口输入的一个字节为CC。
(九)输出命令O
格式:
O端口地址字节值
其功能是向指定的端口输出一个字节。
例如:
O2E812
它表示将一个字节12H送到输出端口2E8。
(十)命名命令N
格式:
N文件标识符[文件标识符]
该命令用给定的两个文件标识符格式化在CS:
5C和CS:
6C的两个文件控制块中(若在调用Debug时具有一个文件标识符,则它已格式化在CS:
5C的文件控制块中),文件控制块是将要介绍的装入命令L和写命令W所需要的。
N命令能把文件标识符和别的参数放至CS:
81开始的参数保存区中。
在CS:
80中保存输入的字符个数,寄存器AX保存前两个文件标识符中的驱动器标志。
例如:
A>DEBUG
NTEST
L
N命令后,用L命令可将TEST调入自己的CS:
100开始的存储区中。
若对正在调试的程序TEST进行调试时,需要用到其它的文件标识符及其它参数,也可用N命令加以实现。
;
例如:
A>DEBUGTEST
N文件1文件2
(十一)装入命令L
格式1:
L<地址><驱动器号><起始逻辑扇区><所读扇区个数n>
其中<地址>的缺省值为CS:
100。
逻辑扇区可由物理扇区号换算得到,以双面双密度盘为例:
物理扇区是按0面0道1区,0面0道2区,……,0面0道9区,0面1道1区,……,0面39道9区,1面0道1区,……,1面39道9区排列。
而逻辑扇区与物理扇区号的对应关系为物理扇区0面0道1扇区至9扇区,逻辑扇区号为0—8;物理扇区1面0道1扇区至9扇区,逻辑扇区号为9—11H;物理扇区0面1道1扇区至9扇区,逻辑扇区号为12—1AH;……。
这样每道先0面后1面一直排下去。
其中<驱动器号>为0、1或2,0表示A驱,1表示B驱,2表示硬盘。
功能:
将<驱动器号>指定的盘上,从<起始
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验二 汇编语言动态调试程序Debug的使用 实验 汇编语言 动态 调试 程序 Debug 使用