先回答你那个debug命令的问题
调试程序DEBUG的特点:
在受控环境中测试程序;
装入,显示或修改任何文件;
执行DOS程序;
完成磁盘实际读/写操作;
建立或汇编汇编语言程序。
DEBUG的命令格式:
[drive:][path] DEBUG [d:][p][filename][.ext][param...]
其中:
drive: 是指定DEBUG文件的磁盘驱动器标识符,DEBUG是外部DOS命令,所以必须把它从磁盘读入内存。若未指定,DOS将使用当前默认磁盘驱动器。
path: 是DOS查找DEBUG文件的一个子目录串表示的路径。若未指定,DOS将使用当前工作目录。
d: 是DEBUG将要调试的文件所在的磁盘驱动器。
p: 是查找DEBUG将要调试的文件所需的子目录路径,若未指定,DOS使用当前目录。
filename[.ext] 是DEBUG将要调试的文件名。
param 是将被调试的程序(或文件)的命令行参数。
附:
DEBUG所完成的初始化动作,假定文件名没有,启动DEBUG:
段寄存器CS、DS、ES和SS置为DEBUG程序后的第一个段。
指令指针寄存器IP置为100H(程序段前缀PSP后的第一个语句)。
堆栈指针SP置为段末或COMMAND.COM暂驻部分的结束地址(其中较小的那个地址)。
其余通用寄存器均置为0,标志寄存器置为下述状态。
NV UP EI PL NE NA PO NC
如果DEBUG命令行含有文件名,段寄存器DS和ES指向PSP。寄存器BX和CX含有程序长度。
DEBUG使用单字符命令:
命令 格式 命令 格式
汇编 A [地址] 命名 N [设备:][路径]文件名[.扩展名]
比较 C [范围] 输出 O 口地址
转出 D [范围]或[地址] 继续执行 P [=地址][值]
键入 E 地址[表] 退出 Q
填入 F 范围表 寄存器 R [寄存器]
执行 G [=地址][地址[地址...]] 搜索 S 范围表
十六进制 H 值 值 跟踪 T [=地址]或[范围]
输入 I 口地址 反汇编 U [地址]或[范围]
装入 L [地址][设备扇区,扇区]] 写 W [地址[设备扇区,扇区]]
移动 M 范围 地址
这些DEBUG命令主要参考清华大学计算机系列教材《IBM-C汇编语言程序设计》一书。
☆ 显示存储单元的命令D(DEBUG),格式为:
- D[address]或
- D[range]
例如,-E DS:100 F3'XYZ'8D
其中F3,‘X’,‘Y’,‘Z’和8D各占一个字节,该命令可以用这五个字节来替代存储单元DS:0100到0104的原先的内容。
第二种格式则是采用逐个单元相继修改的方法。命令格式为:
-E address
例如,-E CS:100
则可能显示为:
18E4:0100 89. -
如果需要把该单元的内容修改为78,则可以直接键入78,再按空格键可接着显示下一个单元的内容,这样可以不断修改相继单元的内容,直到Enter键结束该命令为止。
填写命令F(Fill),其格式为:
-F range list
例如,-F 4BA:0100 5 F3'XYZ'8D
使04BA:0100-0104单元包含指定的五个字节的内容。如果list中的字节数超过指定的范围,则忽略超过的项;如果list的字节数小于指定范围,则重复使用list填入,直到填满指定的所有单元为止。
☆ 检查和修改寄存器内容的命令R(Register),它有三种格式如下:
显示CPU内所有寄存器内容和标志位状态,其格式为:
-R
例如,
-r
AX=0000 BX=0000 CX=010A DX=0000 SP=FFFE BP=0000 SI=0000 DI=0000
DS=18E4 ES=18E4 SS=18E4 CS=18E4 IP=0100 NV UP DI PL NZ NA PO NC
18E4:0100 C70604023801 MOV WORD PTR[0204],0138 DS:0204=0000
其中标志位状态的含义可见下表:
标 志 名 标志为1 标志为0
OF
DF
IF
SF
ZF
AF
PF
CF
溢出(是/否)
方向(减量/增量)
中断(允许/关闭)
符号(负/正)
零(是/否)
辅助进位(是/否)
奇偶(偶/奇)
进位(是/否
OV
DN
EI
NG
ZR
AC
PE
CY
NV
UP
DI
PL
NZ
NA
PO
NC
显示和修改某个寄存器内容,其格式为:
-R register name
例如,键入
-r ax
系统将响应如下:
AX F1F4
:
即AX寄存器的当前内容为F1F4,如不修改则按Enter键,否则,键入欲修改的内容如:
-r bx
BX 0369
:059F
则把BX寄存器的当前内容修改为059F。
显示和修改标志位状态,命令格式为:
-RF
系统将响应,如:
OV DN EI NG ZR AC PE CY -
此时如不修改其内容可按Enter键,否则,建入欲修改的内容,如:
OV DN EI NG ZR AC PE CY - PONZDINV
即可,键入的顺序是任意的。
☆ 运行命令G(Go),其格式为:
-G [=address1][address2[address3 ...]]
其中,地址1指定了运行的起始地址,如不指定则从当前的CS:IP开始运行。后面的地址均为断点地址,当指令执行到断点时,就停止执行并显示当前所有寄存器及标志位的内容,和下一条将要执行的指令。
☆ 跟踪命令T(Trace),有两种格式:
逐条指令跟踪
-T[=address]
从指定地址起执行一条指令后停下来,显示所有寄存器内空及标志位的值。如未指定则从当前的CS:IP开始执行。
多要指令跟踪
-T[=address][value]
从指定地址起执行n条指令后停下来,n由value指定。
☆ 汇编命令A(Assemble),其格式为:
-A [address]
该命令允许键入汇编语言语句,并能把它们汇编成机器代码,相继地存放在从指定地址开始的存储区中。必须注意:DEBUG把键入的数字均看成十六进制数,所以如要键入十进制数,则其后应加以说明,如100D。
☆ 反汇编命令U(Unassemble),有两种格式:
从指定地址开始,反汇编32个字节,其格式为:
-U[range]
例如:
-u 100
18E4:0100 C70604023801 MOV WORD PTR[0204],0138
18E4:0106 C70606020002 MOV WORD PTR[0206],0200
18E4:010C C70608020202 MOV WORD PTR[0208],0202
18E4:0112 BB0402 MOV BX,0204
18E4:0115 E80200 CALL 011A
18E4:0118 CD20 INT 20
18E4:011A 50 PUSH AX
18E4:011B 51 PUSH CX
18E4:011C 56 PUSH SI
18E4:011D 57 PUSH DI
18E4:011E 8B37 MOV SI,[BX]
如果地址被省略则从上一个U命令的最后一条指令的下一个单元开始显示32个字节。
对指定范围内的存储单元进行反汇编,格式为:
-U[range]
例如:
-u 100 10C
18E4:0100 C70604023801 MOV WORD PTR[0204],0138
18E4:0106 C70606020002 MOV WORD PTR[0206],0200
18E4:010C C70608020202 MOV WORD PTR[0208],0202
或
-u 100 112
18E4:0100 C70604023801 MOV WORD PTR[0204],0138
18E4:0106 C70606020002 MOV WORD PTR[0206],0200
18E4:010C C70608020202 MOV WORD PTR[0208],0202
这两种格式是等效的。
☆ 命名命令N(Name),其格式为:
-N filespecs [filespecs]
命令把两个文件标识符格式化在CS:5CH和CS:6CH的两个文件控制块中,以便在其后用L或W命令把文件装入或存盘。filespecs的格式可以是:
[d:][path] filename[.ext]
例如:
-N myprog
-L
-
可把文件myprog装入存储器。
☆ 装入命令L(Load),有两种功能:
把磁盘上指定扇区范围的内容装入到存储器从指定地址开始的区域中。其格式为:
-L[address [drive sector sector]]
装入指定文件,其格式为:
-L[address]
此命令装入已在CS:5CH中格式化了的文件控制块所指定的文件。如未指定地址,则装入CS:0100开始的存储区中。
☆ 写命令W(Write),有两种功能:
把数据写入磁盘的指定扇区。其格式为:
-W address drive sector sector
把数据写入指定的文件中。其格式为:
-W [address]
此命令把指定的存储区中的数据写入由CS:5CH处的文件控制块所指定的文件中。如未指定地址则数据从CS:0100开始。要写入文件的字节数应先放入BX和CX中。
☆ 退出DEBUG命令Q(Quit),其格式为:
-Q
它退出DEBUG,返回DOS。本命令无存盘功能,如需存盘应先使用W命令。 作者: bigblock 时间: 2004-5-14 17:34 标题: 求助!!