汇编(三):DEBUG_汇编debug-程序员宅基地

技术标签: 汇编  debug  windows  

前言

为熟练使用 DEBUG 功能,特展开此次实验,实验内容主要为查看 CPU 和内存,用机器指令和汇编指令编程;
 

什么是 DEBUG?

DEBUG 是 DOS、Windows 都提供的实模式(8086 方式)程序的调试工具。使用它,可以查看 CPU 各种寄存器中的内容、内存的情况和在机器码级跟踪程序的运行。
 

DEBUG 功能

R 命令查看、改变 CPU 寄存器的内容;
D 命令查看内存中的内容;
E 命令改写内存中的内容;
U 命令将内存中的机器指令翻译成汇编指令;
T 命令执行一条机器指令;
A 命令以汇编指令的格式在内存中写入一条机器指令。
 

安装 DEBUG

建议使用 Windows 虚拟机进行实验,最好不要在真机上实验,万一整崩了就麻烦了

现在大多数人的电脑是64位系统,而64位系统已经不再支持命令行模式下进入 debug。那64位系统用户怎样才能进入 debug 模式呢?

下载安装DOSBox和debug.exe:

  1. 通过点击面的链接可以下载 DOSBox 和 debug.exe, 下载地址(密码:6b36)

  2. 安装 DOSBox,其默认安装在 C:\Program Files (x86) 目录下;

  3. 找到 debug.exe,并把你喜欢的位置上,记住目录(等会用到)这里我放在 C:\Windows\system 目录下

完成以上安装之后,我们需要给 DOSBox 配置一个指向 debug.exe 所在目录的虚拟的盘符:

mount c C:\Windows\system

其中,C 是虚拟的盘符,可随意设置,后面跟着的是 debug.exe 所在的目录。需要注意的是,此时这个 C 盘是 mount 命令后 DOSBox 中创建的 C 盘,它映射着我们本地的 C:\Windows\system 目录,但并不是我们电脑本地的 C 盘。

上述一切顺利将会出现如下画面:

修改 DOSBox 配置文件

现在是可以正常进入 debug 模式了,但有一个问题,每次打开 DOSBox 都需要重新输入上面的命令,非常不方便。

其实,DOSBox 的配置文件中有一个 [autoexec] 区段,在这个区段中的命令会在 DOSBox 每一次启动时自动运行,我们可以在这里输入我们的 mount 命令。

  • 在 DOSBos 安装根目录下,有一个名为 DOSBox 0.74 Options.bat 的脚本文件,双击便会自动跳转配置文件了;

  • 打开后,拉到最下面,可以看到 [autoexec] 区段,在这里输入刚才的命令;

  • 保存后重启 DOSBox 就可以直接输入 debug,进入 debug 模式了。

安装完成并且能成功运行之后可别忘了拍摄快照喔~

 

R命令

注意 CS 和 IP 的值,CS=073FIP=0100,也就是说,内存 073F:0100 处的指令为 CPU 当前要读取、执行的指令。在所有寄存器的下方,Debug 还列出了 CS:IP 所指向的内存单元处所存放的机器码,并将它翻译为汇编指令。可以看到,CS:IP 所指向的内存单元为 073F:0100,此处存放的机器码为 0000,对应的汇编指令为 ADD [BX+SI],AL

还可以用 R 命令来改变寄存器中的内容:

修改其他寄存器中的值也是同理的;
 

D命令

用 Debug 的 D 命令,可以查看内存中的内容,D 命令的格式较多,这里只介绍在本次实验中用到的格式。

如果我们想知道内存 10000H 处的内容,可以用 “d 段地址:偏移地址” 的格式来查看,

  • 要查看内存10000H处的内容,首先将这个地址表示为 段地址:偏移地址 的格式,可以是1000:0,然后用 d 1000:0 列出1000:0处的内容。

  • 使用 “d 段地址:偏移地址” 的格式,Debug 将列出从指定内存单元开始的128个内存单元的内容。

  • 使用 D 命令,DEBUG 将输出3部分内容:

    • 中间是从指定地址开始的128个内存单元的内容,用十六进制的格式输出,每行的输出从16的整数倍的地址开始,最多输出16个单元内容;
    • 左边是每行的起始地址;
    • 右边是每个内存单元中的数据对应的可显示的 ASCII 码字符;

在使用 “d段地址:偏移地址” 之后,接着使用 D 命令,可列出后续的内容,如图:


也可以指定 D 命令的查看范围,此时采用 “d段地址:起始偏移地址 结尾偏移地址” 的格式。比如要看1000:0~1000:9 中的内容,可以用 d 1000:0 9 实现,如图:
 

E命令

可以使用 E 命令来改写内存中的内容,比如,要将内存 1000:0~1000:9 单元中的内容分别写为0、1、2、3、4、5、6、7、8、9,可以用 “e起始地址 数据 数据 数据……” 的格式来进行,如图所示:

可以用 E 命令以提问的方式来逐个地修改从某一地址开始的内存单元中的内容,步骤如下:

  • 输入 e 1000:0,按 Enter 键。

  • Debug 显示起始地址1000:0010,和第一单元(即1000:0010单元)的原始内容:00,然后光标停在 . 的后面提示输入想要写入的数据,此时可以有两个选择:

    • 其一,为输入数据(我们输入的是 AA),然后按空格键,即用输入的数据改写当前的内存单元;
    • 其二,为不输入数据,直接按空格键,则不对当前内存单元进行改写;
  • 当前单元处理完成后(不论是改写或没有改写,只要按了空格键,就表示处理完成),Debug 将接着显示下一个内存单元的原始内容,并提示进行修改;

  • 所有希望改写的内存单元改写完毕后,按 Enter 键,E命令操作结束。


当然,也可以用 E 命令写入字符以及字符串,字符用单引号包裹,字符串用双引号;
 

U命令

跟上述操作类似,U 命令是用来查看内存中机器码的含义的;


使用 E 命令向内存中写入机器码:

这三条汇编指令及其机器码其实都在之前有提到过得;
 

T命令

就是执行内存中的机器码,注意 CS:IP 的指向就好了,这里就放别人的图了,


首先用 E 命令向从 1000:0 开始的内存单元中写入了8个字节的机器码;然后用 R 命令查看 CPU 中寄存器的状态,可以看到,CS=0b39HIP=0100H,指向内存 0b39:0100;若要用 T 命令控制 CPU 执行我们写到1000:0的指令,必须先让 CS:IP 指向1000:0;接着用 R 命令修改 CS、IP 中的内容,使 CS:IP 指向 1000:0。

完成上面的步骤后,就可以使用 T 命令来执行我们写入的指令了(此时,CS:IP 指向我们的指令所在的内存单元)。执行 T 命令后,CPU 执行 CS:IP 指向的指令,则1000:0 处的指令 b8 01 00(mov ax,0001) 得到执行,指令执行后,Debug 显示输出 CPU 中寄存器的状态。

注意,指令执行后,AX 中的内容被改写为1,IP 改变为 IP+3 (因为 mov ax,0001 的指令长度为3个字节),CS:IP 指向下一条指令。
 

A命令

A 命令主要的作用是以汇编指令的形式在内存中写入机器指令;


首先用A命令,以汇编语言向从1000:0开始的内存单元中写入了几条指令,然后用 D 命令查看 A 命令的执行结果。可以看到,在使用 A 命令写入指令时,我们输入的是汇编指令,Debug 将这些汇编指令翻译为对应的机器指令,将它们的机器码写入内存。

使用 A 命令写入汇编指令时,在给出的起始地址后直接按 Enter 键表示操作结束。
 

后记

实践是检验真理性的唯一标准!

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_46263782/article/details/120327753

智能推荐

分布式光纤传感器的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告_预计2026年中国分布式传感器市场规模有多大-程序员宅基地

文章浏览阅读3.2k次。本文研究全球与中国市场分布式光纤传感器的发展现状及未来发展趋势,分别从生产和消费的角度分析分布式光纤传感器的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品的价格、产量、产值及全球和中国市场主要生产商的市场份额。主要生产商包括:FISO TechnologiesBrugg KabelSensor HighwayOmnisensAFL GlobalQinetiQ GroupLockheed MartinOSENSA Innovati_预计2026年中国分布式传感器市场规模有多大

07_08 常用组合逻辑电路结构——为IC设计的延时估计铺垫_基4布斯算法代码-程序员宅基地

文章浏览阅读1.1k次,点赞2次,收藏12次。常用组合逻辑电路结构——为IC设计的延时估计铺垫学习目的:估计模块间的delay,确保写的代码的timing 综合能给到多少HZ,以满足需求!_基4布斯算法代码

OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版-程序员宅基地

文章浏览阅读3.3k次,点赞3次,收藏5次。OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版

关于美国计算机奥赛USACO,你想知道的都在这_usaco可以多次提交吗-程序员宅基地

文章浏览阅读2.2k次。USACO自1992年举办,到目前为止已经举办了27届,目的是为了帮助美国信息学国家队选拔IOI的队员,目前逐渐发展为全球热门的线上赛事,成为美国大学申请条件下,含金量相当高的官方竞赛。USACO的比赛成绩可以助力计算机专业留学,越来越多的学生进入了康奈尔,麻省理工,普林斯顿,哈佛和耶鲁等大学,这些同学的共同点是他们都参加了美国计算机科学竞赛(USACO),并且取得过非常好的成绩。适合参赛人群USACO适合国内在读学生有意向申请美国大学的或者想锻炼自己编程能力的同学,高三学生也可以参加12月的第_usaco可以多次提交吗

MySQL存储过程和自定义函数_mysql自定义函数和存储过程-程序员宅基地

文章浏览阅读394次。1.1 存储程序1.2 创建存储过程1.3 创建自定义函数1.3.1 示例1.4 自定义函数和存储过程的区别1.5 变量的使用1.6 定义条件和处理程序1.6.1 定义条件1.6.1.1 示例1.6.2 定义处理程序1.6.2.1 示例1.7 光标的使用1.7.1 声明光标1.7.2 打开光标1.7.3 使用光标1.7.4 关闭光标1.8 流程控制的使用1.8.1 IF语句1.8.2 CASE语句1.8.3 LOOP语句1.8.4 LEAVE语句1.8.5 ITERATE语句1.8.6 REPEAT语句。_mysql自定义函数和存储过程

半导体基础知识与PN结_本征半导体电流为0-程序员宅基地

文章浏览阅读188次。半导体二极管——集成电路最小组成单元。_本征半导体电流为0

随便推点

【Unity3d Shader】水面和岩浆效果_unity 岩浆shader-程序员宅基地

文章浏览阅读2.8k次,点赞3次,收藏18次。游戏水面特效实现方式太多。咱们这边介绍的是一最简单的UV动画(无顶点位移),整个mesh由4个顶点构成。实现了水面效果(左图),不动代码稍微修改下参数和贴图可以实现岩浆效果(右图)。有要思路是1,uv按时间去做正弦波移动2,在1的基础上加个凹凸图混合uv3,在1、2的基础上加个水流方向4,加上对雾效的支持,如没必要请自行删除雾效代码(把包含fog的几行代码删除)S..._unity 岩浆shader

广义线性模型——Logistic回归模型(1)_广义线性回归模型-程序员宅基地

文章浏览阅读5k次。广义线性模型是线性模型的扩展,它通过连接函数建立响应变量的数学期望值与线性组合的预测变量之间的关系。广义线性模型拟合的形式为:其中g(μY)是条件均值的函数(称为连接函数)。另外,你可放松Y为正态分布的假设,改为Y 服从指数分布族中的一种分布即可。设定好连接函数和概率分布后,便可以通过最大似然估计的多次迭代推导出各参数值。在大部分情况下,线性模型就可以通过一系列连续型或类别型预测变量来预测正态分布的响应变量的工作。但是,有时候我们要进行非正态因变量的分析,例如:(1)类别型.._广义线性回归模型

HTML+CSS大作业 环境网页设计与实现(垃圾分类) web前端开发技术 web课程设计 网页规划与设计_垃圾分类网页设计目标怎么写-程序员宅基地

文章浏览阅读69次。环境保护、 保护地球、 校园环保、垃圾分类、绿色家园、等网站的设计与制作。 总结了一些学生网页制作的经验:一般的网页需要融入以下知识点:div+css布局、浮动、定位、高级css、表格、表单及验证、js轮播图、音频 视频 Flash的应用、ul li、下拉导航栏、鼠标划过效果等知识点,网页的风格主题也很全面:如爱好、风景、校园、美食、动漫、游戏、咖啡、音乐、家乡、电影、名人、商城以及个人主页等主题,学生、新手可参考下方页面的布局和设计和HTML源码(有用点赞△) 一套A+的网_垃圾分类网页设计目标怎么写

C# .Net 发布后,把dll全部放在一个文件夹中,让软件目录更整洁_.net dll 全局目录-程序员宅基地

文章浏览阅读614次,点赞7次,收藏11次。之前找到一个修改 exe 中 DLL地址 的方法, 不太好使,虽然能正确启动, 但无法改变 exe 的工作目录,这就影响了.Net 中很多获取 exe 执行目录来拼接的地址 ( 相对路径 ),比如 wwwroot 和 代码中相对目录还有一些复制到目录的普通文件 等等,它们的地址都会指向原来 exe 的目录, 而不是自定义的 “lib” 目录,根本原因就是没有修改 exe 的工作目录这次来搞一个启动程序,把 .net 的所有东西都放在一个文件夹,在文件夹同级的目录制作一个 exe._.net dll 全局目录

BRIEF特征点描述算法_breif description calculation 特征点-程序员宅基地

文章浏览阅读1.5k次。本文为转载,原博客地址:http://blog.csdn.net/hujingshuang/article/details/46910259简介 BRIEF是2010年的一篇名为《BRIEF:Binary Robust Independent Elementary Features》的文章中提出,BRIEF是对已检测到的特征点进行描述,它是一种二进制编码的描述子,摈弃了利用区域灰度..._breif description calculation 特征点

房屋租赁管理系统的设计和实现,SpringBoot计算机毕业设计论文_基于spring boot的房屋租赁系统论文-程序员宅基地

文章浏览阅读4.1k次,点赞21次,收藏79次。本文是《基于SpringBoot的房屋租赁管理系统》的配套原创说明文档,可以给应届毕业生提供格式撰写参考,也可以给开发类似系统的朋友们提供功能业务设计思路。_基于spring boot的房屋租赁系统论文