1、什么是Debug?
Debug是DOS、Windows都提供的实模式(8086方式)程序的调试工具。使用它,可以查看CPU各种寄存器的内容、内存的情况和在机器码级跟踪程序的运行。
我用的是Mac机器,先下载和
1)将masm5文件夹放到某个目录下,例如用户目录~下面
2)双击打来DOSBox
3)挂载,输入mount c: ~/masm5命令,其中~/masm5是第一步中masm5文件夹的实际位置。
4)输入c:
5)输入Debug就可以使用了。
2、Debug的功能
1)用Debug的R命令查看、改变CPU寄存器的内容;
输入r,Enter后能看到寄存器中的值
输入r+空格+寄存器名,Enter后,出现":"作为输入提示,在后面输入要写入的数据,Enter后完成修改
2)用Debug的D命令查看内存中的内容;
输入d+空格+段地址值+":"+偏移地址,Enter后查看内存数据,Debug会列出128个内存单元的内容,如d 1000:9
输入d+空格+段地址值+":"+起始偏移地址+空格+结尾偏移地址,Enter后查看内存数据,Debug会列出对应区域的内存单元的内容,如d 1000:0 9
d+空格+ds+":"+偏移地址
3)用Debug的E命令改写内存中的内容;
"e+空格+起始地址+空格+数据+空格+数据+空格 ..."改写对应内存中的内容
可以用E命令向内存中写入字符,例如用E命令从内存1000:0开始写入数值1、字符a、数值2、字符b、数值3、字符c
-e 1000:0 1 'a' 2 'b' 3 'c' ,其中-表示光标
"e+空格+ds+":"+偏移地址+空格+数据+空格+数据+空格 ..." (内存单元地址前可以直接使用ds段寄存器名字,而不再是常数值)
4)用Debug的U命令将内存中的机器指令翻译成汇编指令
U+空格+段地址值+":"+偏移地址, 将对应内存中的机器指令翻译成汇编指令
U+空格+ds+":"+偏移地址
5)用Debug的T命令执行一条机器指令;
注意:int 21指令需要使用P命令执行。
6)用Debug的A命令以汇编指令的格式在内存中写入一条机器指令;
a+空格+段地址值+偏移地址,然后可以在对应的内存中写入汇编指令
a+空格+ds+偏移地址
7)使用Q命令退出Debug
8)g命令用来调试循环里面的代码
g+空格+偏移地址: 使Debug从当前的CS:IP指向的指令执行,一直到(IP)=偏移地址位置。
9)p命令用来将所有的循环一次走完