环境搭建
在学习汇编时却发现从win7的64位系统开始就无法使用debug.exe了,想要不安装dos虚拟机的方式调试,可以安装dosbox
新建一个dos文件夹(名字也可以自己起),里面新建一个asm文件夹存放汇编文件,新建一个masm文件夹存放所需程序,如下图
安装完成后,先不要打开,找到dosbox文件目录中的DOSBox XX(版本号) Options.bat,双击打开,
mount F: F:\dos
# 添加系统临时变量(此时的 F: 代表的是F:\dos)
set PATH=%PATH%;F:\masm;
# F:\dos:\masm 存放所需的指令程序
F:
# 进入F:\dos文件夹
cd F:\asm
# F:\dos:\asm 这个文件夹存放所有的asm格式文件,同时obj和exe文件也会默认生成在这里
基本操作
(1) 编译
在dosbox中输入masm 即可运行masm(也可以在masm后直接写文件名)
(2)连接
所有命令的作用
下面从
R命令
R命令作用:观看和修改寄存器的值。
在提示符“-”下输入以下命令:R。DEBUG将会显示出当前所有寄存器和标志位的状态。
接下来再输入命令R CX。在提示符“:”后输入100。该命令的作用是将寄存器CX的值设置为100(注意:DEBUG使用的是十六进制,这里的100相当于十进制的256。)
最后再执行R命令,观看修改后的寄存器值。
H命令
H命令作用:计算两个十六进制数的和与差。
在提示符“–”下输入以下命令:H 1 10。结果显示0011 FFF1
运行结果的前一个数是计算出来的和,后一个数是计算出来的差。计算结果均用十六进制形式表示。
D命令
D命令作用:显示内存区域的内容。
在提示符“–”下连续执行命令R、D、D。观看命令执行结果。
前面已经介绍过了,命令R的作用是显示当前寄存器的值。而命令D的作用是显示内存区域的内容,最左边是内存的起始地址,中间以十六进制的形式显示内存值,最右边是以ASCII码的形式显示内存值。每行最多显示16个字节的内容。
命令D可以带参数也可省略参数。设DEBUG启动时DS的值为X,当省略参数时,命令D显示内容以X:100为起始,每次显示128个字节的内容。以后再执行不带参数的命令D时,DEBUG将按上次的位置接着显示下去。
带参数时DEBUG能够显示指定地址范围的内容。带参数的方式有三种:
- 方式一:d [起始位置]。DEBUG从起始位置开始显示128个字节的内容。在提示符“-”下执行命令D 1AF5:100。观看命令执行结果。
- 方式二:d [起始位置] [结束位置]。DEBUG从起始位置开始一直显示到结束位置。在提示符“-”下执行命令D DS:100
1FF。观看命令执行结果。- 方式三:d [起始位置] [L长度],长度以L参数为标识。DEBUG从起始位置开始显示指定长度的内容。在提示符“-”下执行命令D
DS:100 L10。观看命令执行结果。
E命令
E命令作用:改变内存单位的内容。
E命令的使用方式为:E [起始位置]。
在提示符“-”下输入以下命令:E 1AF5:100。
DEBUG首先显示[1AF5:0000]的内容00.,这时可以修改该字节的值。如果还要修改后续的内容,可以按空格键继续。当要跳过某个字节时,可以按连续的两个空格跳到后一个字节去
F命令
F命令作用:使用指定的值填充指定内存区域中的地址。
F命令的使用方式为:F [范围] [填充列表]。
在提示符“-”下输入以下命令:F 1AF5:100 L20 1 2 3 4 5。执行命令D 1AF5:100观看命令执行结果。
说明:该命令是用字节序列01、02、03、04、05轮流填充从1AF5:100开始长度为20H的内存区域。
在提示符“-”下输入以下命令:F 1AF5:100 13F 41 42 43 44。
说明:该命令是用字节序列41、42、43、44轮流填充从1AF5:100开始一直到1AF5:13F的内存区域。
M命令
M命令作用:将指定内存区域的数据复制到指定的地址去。
M命令的使用方式为:M [范围] [指定地址]。
在提示符“-”下输入以下命令:M 1AF5:100 13F 1AF5:140。执行命令D 1AF5:100观看命令执行结果。
C命令
C命令作用:将两块内存的内容进行比较。
C命令的使用方式为:C [范围] [指定地址],意思就是将指定范围的内存区域与从指定地址开始的相同长度的内存区域逐个字节进行比较,列出不同的内容。
在提示符“-”下输入以下命令:C 1AF5:100 13F 1AF5:140。由于两块内容完全相同,所以命令执行后没有任何显示。
在提示符“-”下输入以下命令:C 1AF5:100 107 1AF5:180,比较的区域长度为8个字节。命令执行后列出比较结果不同的各个字节。
S命令
S命令作用:在指定的内存区域中搜索指定的串。
S命令的使用方式为:S [范围] [指定串]。
在提示符“-”下输入以下命令:D 1AF5:100 11F。显示该区域的内存值。
在提示符“-”下输入以下命令:S 1AF5:100 11F 41 42 43 44。搜索该区域是否存在字节串41 42 43 44,并将搜索结果一一列出。
从执行结果可以看出,总共搜索到八处。
A命令
A命令作用:输入汇编指令。
G命令
G命令作用:执行汇编指令。
G命令的使用方法是:G [=起始地址] [断点地址],意思是从起始地址开始执行到断点地址。如果不设置断点,则程序一直运行到中止指令才停止。
U命令
U命令作用:对机器代码反汇编显示。
U命令的使用方法是:U [范围]。如果范围参数只输入了起始地址,则只对20H个字节的机器代码反汇编。执行命令U100,观看反汇编结果。
执行命令U100 10B,观看反汇编结果。该命令的作用是对从100到10B的机器代码进行反汇编。
N命令
N命令作用:设置文件名,为将刚才编写的汇编程序存盘做准备。
W命令
W命令作用:将文件或者特定扇区写入磁盘。
在示例“N命令的使用”中已经实验了如何使用W命令将文件存盘。
在没有很好地掌握汇编语言和磁盘文件系统前,暂时不要使用W命令写磁盘扇区,否则很容易损坏磁盘文件,甚至破坏整个磁盘的文件系统。
L命令
L命令作用:从磁盘中将文件或扇区内容读入内存。
将文件调入内存必须先用DEBUG的N命令设定文件名。
T命令
T命令作用:执行汇编程序,单步跟踪。
T命令的使用方式是T [=地址] [指令数]。如果忽略“地址”的话,T命令从CS:IP处开始运行。“指令数”是要单步执行的指令的数量。
P命令
P命令作用:执行汇编程序,单步跟踪。与T命令不同的是:P命令不会跟踪进入子程序或软中断。
P命令的使用方式与T命令的使用方式完全相同。
I命令
I命令作用:从计算机输入端口读取数据并显示。
I命令的用法是I [端口地址]。例如从3F8号端口读取数据并显示的命令为:I 3F8。
O命令
O命令作用:向计算机输出端口送出数据。
O命令的用法是O [端口地址] [字节值]。例如向278号端口发出数据20H的命令为:I 278 20。
Q命令
Q命令的作用是退出DEBUG,回到DOS状态。