-----------

DEBUG命令 调试 汇编语言程序

一.如何启动debug命令?

 在运行栏里键入:

 debug

 如果不出现黑色命令窗口。则键入:

 c:/windows/system32/debug

 

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

即出现debug命令窗口,如下图

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

另一种方法启动debug是:

按 开始->程序->命令指示符

在里面键入debug后,按回车

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

按回车后弹出debug命令窗口,如下

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

 

二,debug的主要命令

 

1,显示修改寄存器命令R    (Register)

      R;★显示所有寄存器和标志位状态;

         ★显示当前CS:IP指向的指令。

          

       标志                   标志=1         标志=0

        OF                      OV                NV

        DF                      DN                UP

        IF                      EI                DI

        SF                      NG                PL

        ZF                      ZR                NZ

        AF                      AC                NA

        PF                      PE                PO

        CF                      CY                NC

 

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

 

2,汇编命令A  (Assemble)

       A [地址];从指定的地址开始输入符号指令;如省略地址,则接着上一个A命令的最后一个单元开始;若第一次使用A命令省略地址,则从当前CS:IP开始(通常是CS:100)。

       注释:①在DEBUG下编写简单程序即使用A命令。

       ②每条指令后要按回车。

       ③不输入指令按回车,或按Ctrl+C结束汇编。

       ④支持所有8086符号硬指令,伪指令只支持DB、DW,不支持各类符号名。

 

  3.运行程序命令G   (Go)

       ① G;从CS:IP指向的指令开始执行程序,直到程序结束或遇到INT 3。

       ② G=地址;从指定地址开始执行程序,直到程序结束或遇到INT 3。

       ③ G 断点1[,断点2,…断点10];从CS:IP指向的指令开始执行程序,直到遇到断点。

       ④G=地址 断点1[,断点2,…断点10]

    -G ;从CS:IP指向的指令开始执行程序。

    -G=0100 ;从指定地址开始执行程序。

    -G=0100 0104

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

 

4.反汇编命令  U   (Unassemble)

反汇编字节并显示相应的原语句,其中包括地址和字节值。反汇编代码看起来象已汇编文件的列表。
u [range]
参数

如果在没有参数的情况下使用,则 u 命令分解 20h 字节(默认值),从前面 u 命令所显示地址后的第一个地址开始。
range
指定要反汇编代码的起始地址和结束地址,或起始地址和长度。 
有关显示内存部分内容的信息,请参看Debug D(转储)。
范例
要反汇编 16 (10h) 字节,从地址 04BA:0100 开始,请键入以下命令:
u04ba:10l0

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

 

5.内存16进制表示 D     (Dump)

显示一定范围内存地址的内容。
d [range]
参数
range
指定要显示其内容的内存区域的起始和结束地址,或起始地址和长度。如果不指定 range,Debug 程序将从以前 d 命令中所指定的地址范围的末尾开始显示 128 个字节的内容。
有关显示寄存器内容的信息,请参看Debug R(寄存器)。
说明
当使用 d 命令时,Debug 以两个部分显示内存内容:十六进制部分(每个字节的值都用十六进制格式表示)和 ASCII 码部分(每个字节的值都用 ASCII 码字符表示)。每个非打印字符在显示的 ASCII 部分由句号 (.) 表示。每个显示行显示 16 字节的内容,第 8 字节和第 9 字节之间有一个连字符。每个显示行从 16 字节的边界上开始。
范例
假定键入以下命令:
dcs:100 10f
Debug 按以下格式显示范围中的内容:
04BA:0100 54 4F 4D 00 53 41 57 59-45 52 00 00 00 00 00 00 TOM.SAWYER......
如果在没有参数的情况下键入 d 命令,Debug 按以前范例中所描述的内容来编排显示格式。显示的每行以比前一行的地址大 16 个字节(如果是显示 40 列的屏幕,则为 8 个字节)的地址开头。
对于后面键入的每个不带参数的 d 命令,Debug 将紧接在最后显示的命令后立即显示字节内容。
如果键入以下命令,Debug 将从 CS:100 开始显示 20h 个字节的内容:
dcs:100 l 20
如果键入以下命令,Debug 将显示范围从 CS 段的 100h 到 115h 中所有字节的内容:
dcs:100 115

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

 

6.修改内存字节 E      (Enter)

将数据输入到内存中指定的地址。
可以按十六进制或 ASCII 格式键入数据。以前存储在指定位置的任何数据全部丢失。
e address [list]
参数
address
指定输入数据的第一个内存位置。

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

list
指定要输入到内存的连续字节中的数据。
有关集成记忆码的信息,请参看Debug A(汇编)。
有关显示内存部分内容的信息,请参看Debug D (转储)。
说明
使用 address 参数
如果在没有指定可选的 list 参数的值情况下指定 address 的值,Debug 将显示地址和内容,在下一行重复地址,并等待您的输入。此时,您可以执行下列操作之一:
替换字节值。为此,请在当前值后键入新值。如果您键入的值不是有效的十六进制值,或该值包含两个以上的数字,则 Debug 不会回显无效或额外的字符。
进入下一个字节。为此,请按 SPACEBAR(空格键)。要更改该字节中的值,请在当前值后键入新值。如果按 SPACEBAR(空格键)时,移动超过了 8 位界限,Debug 程序将显示新的一行并在行首显示新地址。
返回到前一个字节。为此,请按 HYPHEN 键 (-)。可以反复按 HYPHEN 键 (-) 向后移动超过多个字节。在按 HYPHEN 时,Debug 开始新行并显示当前地址和字节值。
停止执行 e 命令。为此,请按 ENTER 键。在任何字节位置都可以按 ENTER。
使用 list 参数
如果指定 list 参数的值,随后的 e 命令将使用列表中的值替换现有的字节值。如果发生错误,将不更改任何字节值。
List 值可以是十六进制字节或字符串。使用空格、逗号或制表符来分隔值。必须将字符串包括在单或双引号中。
范例
假定键入以下命令:
ecs:100
Debug 按下面的格式显示第一个字节的内容:
04BA:0100 EB.
要将该值更改为 41,请在插入点键入 41,如下所示:
04BA:0100 EB.41_
可以用一个 e 命令键入连续的字节值。在键入新值后按 SPACEBAR(空格键),而不是按 ENTER 键。Debug 显示下一个值。在此范例中,如果按三次 SPACEBAR(空格键),Debug 将显示下面的值:
04BA:0100 EB.41 10. 00. BC._
要将十六进制值 BC 更改为 42,请在插入点键入 42,如下所示:
04BA:0100 EB.41 10. 00. BC.42_
假定决定值 10 应该是 6F。要纠正该值,请按 HYPHEN 键两次以返回到地址 0101(值 10)。Debug 显示以下内容:
04BA:0100 EB.41 10. 00. BC.42-
04BA:0102 00.-
04BA:0101 10._
在插入点键入 6f 更改值,如下所示:
04BA:0101 10.6f_
按 ENTER 停止 e 命令并返回到 Debug 提示符下。
以下是字符串项的范例:
eds:100 "This is the text example"
该字符串将从 DS:100 开始填充 24 个字节

 

 7.  P: 循环或子程序处理(Procedure)   格式:P[=地址] [命令数]
         地址:  执行的起始地址。
         指令数:执行的指令条数。
   用途:*循环或子程序处理。将循环、串指令、软件中断或子程序调用
         视为单语句。执行中了,显示目标程序寄存器内容、标志位状态
         和下一条要执行的指令。
         *若地址参数中无段址,则使用CS中的值。完全忽略地址时,则从
         程序中的CS:IP指定位置开始执行。

DEBUG命令 <wbr>调试 <wbr>汇编语言程序

 退出debug程序   Q    (Quit)

 停止 Debug 会话,不保存当前测试的文件。
当您键入 q 以后,控制返回到 DOS 的命令提示符。
q
参数
该命令不带参数。