DEBUG是为汇编语言设计的一种高度工具,它通过单步、设置断点等方式为汇编语言程序员提供了非常有效的调试手段。\x0d\x0a一、DEBUG程序的调用\x0d\x0a在DOS的提示符下,可键入
命令:\x0d\x0aC:\DEBUG [D:][PATH][FILENAME[.EXT]][PARM1][PARM2]\x0d\x0a其中,文件名是被调试文件的名字。如用户键入文件,则DEBUG将指定的文件装入存储器中,用户可对其进行调试。如果未键入文件名,则用户可以用当前存储器的
内容工作,或者用DEBUG命令N和L把需要的文件装入存储器后再进行调试。命令中的D指定驱动器PATH为路径,PARM1和PARM2则为运行被调试文件时所需要的命令参数。\x0d\x0a在DEBUG程序调入后,将出现提示符,此时就可用DEBUG命令来调试程序。\x0d\x0a二、DEBUG的主要命令\x0d\x0a1、显示存储单元的命令D(DUMP),格式为:\x0d\x0a_D[address]或_D[range]\x0d\x0a例如,按指定范围显示存储单元内容的方法为:\x0d\x0a-d100 120\x0d\x0a18E4:0100 c7 06 04 02 38 01 c7 06-06 02 00 02 c7 06 08 02 G...8.G.....G...\x0d\x0a18E$:0110 02 02 bb 04 02 e8 02 00-CD 20 50 51 56 57 8B 37 ....h..M PQVW.\x0d\x0a7\x0d\x0a18E4:0120 8B\x0d\x0a其中0100至0120是DEBUG显示的单元内容,左边用十六进制表示每个字节,右边用ASCII字符表示每个字节,·表示不可显示的字符。这里没有指定段地址,D命令自动显示DS段的内容。如果只指定首地址,则显示从首地址开始的80个字节的内容。如果完全没有指定地址,则显示上一个D命令显示的最后一个单元后的内容。\x0d\x0a2、修改存储单元内容的命令有两种。\x0d\x0a·输入命令E(ENTER),有两种格式如下:第一种格式可以用给定的内容表来替代指定范围的存储单元内容。命令格式为:\x0d\x0a-E address[list]\x0d\x0a例如,-E DS:100 F3'XYZ'8D\x0d\x0a其中F3,'X','Y','Z'和各占一个字节,该命令可以用这五个字节来替代存储单元DS:0100到0104的原先的内容。\x0d\x0a第二种格式则是采用逐个单元相继修改的方法。命令格式为:\x0d\x0a-E address\x0d\x0a例如,-E DS:100\x0d\x0a则可能显示为:\x0d\x0a18E4:0100 89.-\x0d\x0a如果需要把该单元的内容修改为78,则用户可以直接键入78,再按“空格”键可接着显示下一个单元的内容,如下:\x0d\x0a18E4:0100 89.78 1B.-\x0d\x0a这样,用户可以不断修改相继单元的内容,直到用ENTER键结束该命令为止。\x0d\x0a·填写命令F(FILL),其格式为:\x0d\x0a-F range list\x0d\x0a例如:-F 4BA:0100 5 F3'XYZ'8D\x0d\x0a使04BA:0100~0104单元包含指定的五个字节的内容。如果list中的字节数超过指定的范围,则忽略超过的项;如果list的字节数小于指定的范围,则重复使用list填入,直到填满指定的所有单元为止。\x0d\x0a3)检查和修改
寄存器内容的命令R(register),它有三种格式如下:\x0d\x0a·显示CPU内所有寄存器内容和标志位状态,其格式为:\x0d\x0a-R\x0d\x0a例如,-r\x0d\x0aAX=0000 BX=0000 CX=010A DX=0000 SP=FFFE BP=0000 SI=0000 DI=0000\x0d\x0aDS=18E4 ES=18E4 SS=18E4 CS=18E4 IP=0100 NV UP DI PL NZ NA PO NC\x0d\x0a18E4:0100 C70604023801 MOV WORD PTR [0204],0138 DS:0204=0000\x0d\x0a·显示和修改某个寄存器内容,其格式为:\x0d\x0a-R register name\x0d\x0a例如,键入\x0d\x0a-R AX\x0d\x0a系统将响应如下:\x0d\x0aAX F1F4\x0d\x0a:\x0d\x0a即AX寄存器的当前内容为F1F4,如不修改则按ENTER键,否则,可键入欲修改的内容,如:\x0d\x0a\x0d\x0a-R bx\x0d\x0aBX 0369\x0d\x0a:059F\x0d\x0a则把BX寄存器的内容修改为059F。\x0d\x0a·显示和修改标志位状态,命令格式为:\x0d\x0a-RF系统将响应,如:\x0d\x0aOV DN EI NG ZR AC PE CY-\x0d\x0a此时,如不修改其内容可按ENTER键,否则,可键入欲修改的内容,如:\x0d\x0aOV DN EI NG ZR AC PE CY-PONZDINV\x0d\x0a即可,可见键入的顺序可以是任意的。\x0d\x0a4)运行命令G,其格式为:\x0d\x0a-G[=address1][address2[address3?]]\x0d\x0a其中,地址1指定了运行的起始地址,如不指定则从当前的CS:IP开始运行。后面的地址均为断点地址,当指令执行到断点时,就停止执行并显示当前所有寄存器及标志位的内容,和下一条将要执行的指令。\x0d\x0a5)跟踪命令T(Trace),有两种格式:\x0d\x0a·逐条指令跟踪\x0d\x0a-T [=address]\x0d\x0a从指定地址起执行一条指令后停下来,显示所有寄存器内容及标志位的值。如未指定地址则从当前的CS:IP开始执行。\x0d\x0a·多条指令跟踪\x0d\x0a-T [=address][value]\x0d\x0a从指定地址起执行n条指令后停下来,n由value指定。\x0d\x0a6)汇编命令A(Assemble),其格式为:\x0d\x0a-A[address]\x0d\x0a该命令允许键入汇编语言语句,并能把它们汇编成机器代码,相继地存放在从指定地址开始的存储区中。必须注意:DEBUG把键入的数字均看成十六进制数,所以如要键入十进制数,则其后应加以说明,如100D。\x0d\x0a7)反汇编命令U(Unassemble)有两种格式。\x0d\x0a·从指定地址开始,反汇编32个字节,其格式为:\x0d\x0a-U[address]\x0d\x0a例如:\x0d\x0a-u100\x0d\x0a18E4:0100 C70604023801 MOV WORD PTR[0204],0138\x0d\x0a18E4:0106 C70606020002 MOV WORD PTR[0206],0200\x0d\x0a18E4:010C C70606020202 MOV WORD PTR[0208],0202\x0d\x0a18E4:0112 BBO4O2 MOV BX,0204\x0d\x0a18E4:0115 E80200 CALL 011A\x0d\x0a18E4:0118 CD20 INT 20\x0d\x0a18E4:011A 50PUSH AX\x0d\x0a18E4:011B 51PUSH CX\x0d\x0a18E4:011C 56PUSH SI\x0d\x0a18E4:011D 57PUSH DI\x0d\x0a18E4:011E 8B37 MOV SI,[BX]\x0d\x0a如果地址被省略,则从上一个U命令的最后一条指令的下一个单元开始显示32个字节。\x0d\x0a·对指定范围内的存储单元进行反汇编,格式为:\x0d\x0a-U[range]\x0d\x0a例如:\x0d\x0a-u100 10c\x0d\x0a18E4:0100 C70604023801 MOV WORD PTR[0204],0138\x0d\x0a18E4:0106 C70606020002 MOV WORD PTR[0206],0200\x0d\x0a18E4:010C C70606020202 MOV WORD PTR[0208],0202\x0d\x0a或\x0d\x0a-u100 112\x0d\x0a18E4:0100 C70604023801 MOV WORD PTR[0204],0138\x0d\x0a18E4:0106 C70606020002 MOV WORD PTR[0206],0200\x0d\x0a18E4:010C C70606020202 MOV WORD PTR[0208],0202\x0d\x0a\x0d\x0a可见这两种格式是等效的。\x0d\x0a8)命名命令N(Name),其格式为:\x0d\x0a-N filespecs [filespecs]\x0d\x0a命令把两个文件标识符格式化在CS:5CH和CS:6CH的两个文件控制块中,以便在其后用L或W命令把文件装入存盘。filespecs的格式可以是:\x0d\x0a[d:][path] filename[.ext]\x0d\x0a例如,\x0d\x0a-N myprog\x0d\x0a-L\x0d\x0a-\x0d\x0a可把文件myprog装入存储器。\x0d\x0a9)装入命令(Load),有两种功能。\x0d\x0a·把磁盘上指定扇区范围的内容装入到存储器从指定地址开始的区域中。其格式为:\x0d\x0a-L[address[drive sector sector]\x0d\x0a·装入指定文件,其格式为:\x0d\x0a-L[address]\x0d\x0a此命令装入已在CS:5CH中格式化了文件控制块所指定的文件。如未指定地址,则装入CS:0100开始的存储区中。\x0d\x0a10)写命令W(Write),有两种功能。\x0d\x0a·把数据写入磁盘的指定扇区。其格式为:\x0d\x0a-W address drive sector sector\x0d\x0a·把数据写入指定的文件中。其格式为:\x0d\x0a-W[address]\x0d\x0a此命令把指定的存储区中的数据写入由CS:5CH处的文件控制块所指定的文件中。如未指定地址则数据从CS:0100开始。要写入文件的字节数应先放入BX和CX中。\x0d\x0a11)退出DEBUG命令Q(Quit),其格式为:\x0d\x0a-Q\x0d\x0a它退出DEBUG,返回DOS。本命令并无存盘功能,如需存盘应先使用W命令。
1、点击桌面左下角的【开始】;在搜索栏目中,输入cmd;在d出的菜单中,选中cmd,回车。
2、这个时候打开了win7系统的控制台DOS窗口。在窗口中,输入命令debug。
3、打开了程序debug.exe。使用a命令,在指定地址中,写入指令,为下面的实验准备一下。
4、使用G命令查看ax寄存器的初始值。此时寄存器中,ax寄存器的初始值为0000,ip寄存器初始值为0100。
5、G语言中-t 表示执行IP位置的助记符指令。输入命令-t,此时(ax)=0012,表示执行有效地址为0100处的指令。
6、-t=地址 表示执行指定地址处的指令。输入-t=0103。程序执行0103出的指令,(ax)=0034。
在Windows 95/98的环境中,打开命令窗口的步骤为:点击“开始”→“运行”,输入“command”命令; 在WindowsXP及WIN7的环境中,打开命令窗口的步骤为:点击“开始”→“运行”,输入“cmd”命令;
2.启动DEBUG
在命令窗口中启动DEBUG,启动命令一般为:DEBUG [文件名] [参数表]。其中:文件名指定被调试的文件,其包括名和后缀,参数表是被调试文件运行时所需要的参数。被调试的文件可以是系统中的任何文件,但通常它们的 后缀为.EXE或.COM。 当DEBUG启动成功后,将显示连接符“-”,这时,可输入各种DEBUG命令。DEBUG中所有命令及其含义如DEBUG各命令功能说明表 所示。 关于使用命令的几点说明:在提示符“-”下才能输入命令,在按“回车”键后,该命令才开始执行命令是单个字母,命令和参数的大小写可混合输入可用F1、 F2、F3、Ins、Del、左移键、右移键等编辑键来编辑本行命令当命令出现语法错误时,将在出错位置显示“^ Error”可用Ctrl+C或Ctrl+Break来终止当前命令的执行,还可用Ctrl+S或Ctrl+Num Lock来暂停屏幕显示(当连续不断地显示信息时)
以下通过实现十九个示例来熟悉DEBUG的命令集和基本的汇编指令。
R命令的使用
R命令作用:观看和修改寄存器的值。
在提示符“-”下输入以下命令:R。DEBUG将会显示出当前所有寄存器和标志位的状态。
接下来再输入命令RCX。在提示符“:”后输入100。该命令的作用是将寄存器CX的值设置为100(注意:DEBUG使用的是十六进制,这里的100相当于十进制的256。)
最后再执行R命令,观看修改后的寄存器值。
H命令的使用
H命令作用:计算两个十六进制数的和与差。
在提示符“–”下输入以下命令:H 10 1。观看命令执行结果。
运行结果的前一个数是计算出来的和,后一个数是计算出来的差。计算结果均用十六进制形式表示。
评论列表(0条)