汇编命令
汇编语言Debug命令详解
DEBUG的常用命令:A,U,R,T,D,E,Q 等等

汇编语言DEBUG命令详解

文章目录

  • 汇编语言DEBUG命令详解
    • R命令的使用
    • H命令的使用
    • D命令的使用
    • E命令的使用
    • F命令的使用
    • M命令的使用
    • C命令的使用
    • S命令的使用
    • A命令的使用
    • G命令的使用
    • U命令的使用
    • N命令的使用
    • W命令的使用
    • L命令的使用
    • T命令的使用
    • P命令的使用
    • I命令的使用
    • O命令的使用
    • Q命令的使用

R命令的使用

作用:观看和修改寄存器的值。
在提示符“-”下输入以下命令:R。DEBUG将会显示出当前所有寄存器和标志位的状态。
接下来再输入命令rax。在提示符“:”后输入100。该命令的作用是将寄存器ax的值设置为100(注意:DEBUG使用的是十六进制,这里的100相当于十进制的256。)
最后再执行r命令,观看修改后的寄存器值。

H命令的使用

H命令作用:计算两个十六进制数的和与差。
在提示符“–”下输入以下命令:h 10 1。观看命令执行结果。

运行结果的前一个数是计算出来的和,后一个数是计算出来的差。计算结果均用十六进制形式表示。

D命令的使用

D命令作用:显示内存区域的内容。
在提示符“–”下连续执行命令R、D、D。观看命令执行结果。

前面已经介绍过了,命令R的作用是显示当前寄存器的值。而命令D的作用是显示内存区域的内容,最左边是内存的起始地址,中间以十六进制的形式显示内存值,最右边是以ASCII码的形式显示内存值。每行最多显示16个字节的内容。
命令D可以带参数也可省略参数。设DEBUG启动时DS的值为X,当省略参数时,命令D显示内容以X:100为起始,每次显示128个字节的内容。以后再执行不带参数的命令D时,DEBUG将按上次的位置接着显示下去。
带参数时DEBUG能够显示指定地址范围的内容。带参数的方式有三种:
方式一:d [起始位置]。DEBUG从起始位置开始显示128个字节的内容。在提示符“-”下执行命令d 1000:100。观看命令执行结果。

方式二:d [起始位置] [结束位置]。DEBUG从起始位置开始一直显示到结束位置。在提示符“-”下执行命令d 1000:100 200。观看命令执行结果。

方式三:d [起始位置] [L长度],长度以L参数为标识。DEBUG从起始位置开始显示指定长度的内容。在提示符“-”下执行命令d ds:100 L10。观看命令执行结果。

E命令的使用

E命令作用:改变内存单位的内容。
E命令的使用方式为:E [起始位置]。
在提示符“-”下输入以下命令:e 1000:100。

DEBUG首先显示[1000:100]的内容01.,这时可以修改该字节的值。如果还要修改后续的内容,可以按空格键继续。当要跳过某个字节时,可以按连续的两个空格跳到后一个字节去。

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命令作用:输入汇编指令。
以下的程序要在屏幕上显示“ABCD”四个字符。
首先用E命令将“ABCD” 四 个 字 符 预 先 放 在 内 存 C S : 200 处 , 然 后 执 行 A 100 命 令 输 入 汇 编 程 序 代 码 : M O V A X , C S M O V D S , A X M O V D X , 200 M O V A H , 9 I N T 21 I N T 20 ( 说 明 : 前 两 行 汇 编 指 令 用 于 将 段 寄 存 器 C S 的 值 赋 给 段 寄 存 器 D S 。 第 三 到 第 五 行 汇 编 代 码 的 作 用 是 显 示 以 “ ”四个字符预先放在内存CS:200处,然后执行A100命令输入汇编程序代码: MOV AX,CS MOV DS,AX MOV DX,200 MOV AH,9 INT 21 INT 20 (说明:前两行汇编指令用于将段寄存器CS的值赋给段寄存器DS。第三到第五行汇编代码的作用是显示以“”四个字符预先放在内存CS:200处,然后执行A100命令输入汇编程序代码:MOVAX,CSMOVDS,AXMOVDX,200MOVAH,9INT21INT20(说明:前两行汇编指令用于将段寄存器CS的值赋给段寄存器DS。第三到第五行汇编代码的作用是显示以“”为结尾的字符串。最后一行用于结束程序。)

G命令的使用

G命令作用:执行汇编指令。
G命令的使用方法是:G [=起始地址] [断点地址],意思是从起始地址开始执行到断点地址。如果不设置断点,则程序一直运行到中止指令才停止。
在设置完示例九的的内存数据并且输入完示例九的程序后运行这些汇编代码。在DEBUG中执行命令G=100,观看运行结果。

汇编程序运行后在屏幕上显示出“ABCD”四个字符。
接下来在DEBUG中执行G=100 10B,意思是从地址CS:100开始,一直运行到CS:10B停止。观看运行结果。
命令执行后,不但显示出字符串“ABCD”,而且列出当前寄存器和标志位的值。

g命令在loop中的使用:
使用loop循环时,如果要跳出循环执行后面的代码,可以先用u命令查看代码的偏移地址,在用g命令跳转到此偏移到此代码处,如下:

用u命令可以看到循环的命令位于0b40:000b,所以要跳出循环就用 g 000b 即可。

U命令的使用

U命令作用:对机器代码反汇编显示。
U命令的使用方法是:U [范围]。如果范围参数只输入了起始地址,则只对20H个字节的机器代码反汇编。执行命令U100,观看反汇编结果。
执行命令U100 10B,观看反汇编结果。该命令的作用是对从100到10B的机器代码进行反汇编。

N命令的使用

N命令作用:设置文件名,为将刚才编写的汇编程序存盘做准备。
以下的DEBUG命令序列作用将刚才的汇编程序存为磁盘的COM可执行程序。
D200 20F
U100 10C
N E:\FIRST.COM
RCX
:110
W
第一和第二条命令的作用是检查一下刚才编写的汇编指令。第三条命令的作用是设置存盘文件名为E:\FIRST.COM,第四条命令的作用是设置存盘文件大小为110H个字节。最后一条命令是将文件存盘。

文件存盘后执行E:\FIRST.COM,观看存盘的可执行文件的运行效果。

W命令的使用

W命令作用:将文件或者特定扇区写入磁盘。
在示例“N命令的使用”中已经实验了如何使用W命令将文件存盘。
在没有很好地掌握汇编语言和磁盘文件系统前,暂时不要使用W命令写磁盘扇区,否则很容易损坏磁盘文件,甚至破坏整个磁盘的文件系统。

L命令的使用

L命令作用:从磁盘中将文件或扇区内容读入内存。
将文件调入内存必须先用DEBUG的N命令设定文件名。以下例子是将E:\FIRST.COM读入内容。
N FIRST.COM
L
观看调入程序的汇编代码可以使用DEBUG的U命令,用U100观看调入的COM文件。


读取磁盘扇区的方式是:L [内存地址] [磁盘驱动器号] [起始扇区] [扇区数]。“内存地址”指定要在其中加载文件或扇区内容的内存位置,如果不指定“内存地址”的话,DEBUG将使用CS寄存器中的当前地址。“磁盘驱动器号”指定包含读取指定扇区的磁盘的驱动器,该值是数值型:0=A,1=B,2=C等。“起始扇区”指定要加载其内容的第一个扇区的十六进制数。“扇区数”指定要加载其内容的连续扇区的十六进制数。
只有要加载特定扇区的内容而不是加载文件时,才能使用[磁盘驱动器号] [起始扇区] [扇区数]参数。
例如:要将C盘第一扇区读取到内存DS:300的位置,相应的DEBUG命令为L DS:300 2 1 1。但是由于Windows操作系统对文件系统的保护,这条命令可能会被操作系统禁止运行。

T命令的使用

T命令作用:执行汇编程序,单步跟踪。
T命令的使用方式是T [=地址] [指令数]。如果忽略“地址”的话,T命令从CS:IP处开始运行。“指令数”是要单步执行的指令的数量。
以下示例对E:\FIRST.COM进行单步跟踪。
N E:\FIRST.COM
L
U100 10B
R
T=100
T

第一、二条命令是装入文件,第三条命令是列出程序反汇编代码,第四条命令是显示当前寄存器值,第五条命令是从CS:100处开始单步跟踪,第六条命令是继续跟踪后续的指令。

P命令的使用

P命令作用:执行汇编程序,单步跟踪。与T命令不同的是:P命令不会跟踪进入子程序或软中断。
P命令的使用方式与T命令的使用方式完全相同。

p命令还可以用于结束本次循环,进入下一次循环。

I命令的使用

I命令作用:从计算机输入端口读取数据并显示。
I命令的用法是I [端口地址]。例如从3F8号端口读取数据并显示的命令为:I 3F8。这里不对该命令做解释。

O命令的使用

O命令作用:向计算机输出端口送出数据。
O命令的用法是O [端口地址] [字节值]。例如向278号端口发出数据20H的命令为:I 278 20。这里不对该命令做解释。

Q命令的使用

Q命令的作用是退出DEBUG,回到DOS状态。

来源:https://www.cnblogs.com/tiger2soft/p/5094917.html

汇编语言DEBUG命令||常用命令 详解:A,U,R,T,D,E,Q相关推荐

  1. free命令常用参数详解

    free命令常用参数详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在运维期间我们会经常去查看服务器硬件信息,比如说内存,大家可能知道看内存用"[root@yinzh ...

  2. linux下的arp刷新命令详解,linux arp 命令常用参数详解

    linux arp 命令常用参数详解 linux arp 命令常用参数详解 显示和修改地址解析协议(ARP)使用的"IP 到物理"地址转换表. ARP -s inet_addr e ...

  3. k8s学习-kubectl命令常用选项详解与实战

    目录 概述 语法 资源类型 输出选项 实战 基本命令 create get edit delete 集群管理 cluster-info top cordon && uncordon d ...

  4. Vim 命令常用功能详解

    Vim编辑器 文本编辑器 , 字处理器 ASCII vi:Visual Interface vim :VI iMproved 全屏编辑器,模式化编辑器 vim 模式: 编辑模式(命令模式) 输入模式 ...

  5. 汇编语言DEBUG命令详解||汇编命令||DEBUG的常用命令:A,U,R,T,D,E,Q 等等

    汇编命令 汇编语言Debug命令详解 DEBUG的常用命令:A,U,R,T,D,E,Q 等等 汇编语言DEBUG命令详解 文章目录 汇编语言DEBUG命令详解 R命令的使用 H命令的使用 D命令的使用 ...

  6. linux命令vi作用,详解Linux常用命令的用法(二)――――文本编辑器命令vi/vim

    vi/vim介绍 它们都是多模式编辑器,不同的是vim 是vi的升级版本,它不仅兼容vi的所有指令,而且还有一些新的特性在里面. 1.vi和vim的区别: 就是在进入一般命令模式后,当按下(i.I.o ...

  7. docker实践(2)常用命令和DockerFile详解

    <docker实践(1) 入门和springBoot实践部署> <docker实践(2)常用命令和DockerFile详解> <docker实践(3) 仓库registr ...

  8. Linux常用基本命令详解(二)-------磁盘分区和磁盘管理类命令

    Linux常用基本命令详解(一) Linux常用基本命令详解(二)-------磁盘分区和磁盘管理类命令 Linux常用基本命令详解(三) 1.磁盘分区 磁盘分区(系统分区)是使用分区编辑器(part ...

  9. 计算机常用命令ipconfg,ipconfig命令有什么作用?几个常用的ipconfig命令使用方法详解...

    ipconfig命令有什么作用?在使用Windows系统的过程中,我们经常会使用CMD命令提示符.而ipconfig是命令提示符比较常用的命令之一,很多用户不知道如何使用ipconfig命令,下面装机 ...

最新文章

  1. IPv4的核心管理功能/proc/sys/net/ipv4/*
  2. MySQL(三)数据库的六种约束、表的关系、三大范式
  3. 高级SmartGWT教程,第1部分
  4. Java静态方法与非静态方法的泛型
  5. python内置方法怎么使用_python的常用内置方法
  6. 这家武汉工厂如果停工,全球都不答应
  7. C#LeetCode刷题之#350-两个数组的交集 II(Intersection of Two Arrays II)
  8. 启动服务提示-bash: mongod: command not found
  9. 基于谷歌街景多位数字识别技术:TensorFlow的车牌号识别系统
  10. 图像增强算法效果评价指标及实现
  11. 如何自己打印计算机准考证,如何打印计算机准考证
  12. 安装Fedora 20桌面版并配置(gnome桌面环境)
  13. 中山大学本科偏微分方程试题
  14. 计算机未安装OCR应用程序,OCR使用的常见问题及解决(转载)
  15. Apache POI 读取、写入Excel文件教程
  16. 蚂蚁笔记 linux安装教程,群晖docker安装蚂蚁笔记安装教程
  17. 渗透测试工程师面试题大全(三)
  18. 每日一句: I don't think it's necessary for you to give up
  19. 关于构建之法中小飞问题的个人看法
  20. H、Magic necklace

热门文章

  1. 3D引擎渲染效率如何提升
  2. Uniswap V2白皮书翻译
  3. linux 僵死日志,关于僵死进程
  4. java 线程僵死_线程池子线程超时(僵死)问题
  5. 深度强化学习系列之(13): 深度强化学习实验中应该使用多少个随机种子?
  6. android 后台播放,实现后台播放  |  Android 开发者  |  Android Developers
  7. Frameset打印frame的问题(downmoon)
  8. 同济大学核心学术刊物基本目录_同济大学:《装配式混凝土结构连接节点构造》图集解读,值得收藏...
  9. python随机生成8位字符串
  10. segmap走过的坑