汇编(三):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

智能推荐

使用nginx解决浏览器跨域问题_nginx不停的xhr-程序员宅基地

文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr

在 Oracle 中配置 extproc 以访问 ST_Geometry-程序员宅基地

文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc

Linux C++ gbk转为utf-8_linux c++ gbk->utf8-程序员宅基地

文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8

IMP-00009: 导出文件异常结束-程序员宅基地

文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束

python程序员需要深入掌握的技能_Python用数据说明程序员需要掌握的技能-程序员宅基地

文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求

Spring @Service生成bean名称的规则(当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致)_@service beanname-程序员宅基地

文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname

随便推点

二叉树的各种创建方法_二叉树的建立-程序员宅基地

文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立

解决asp.net导出excel时中文文件名乱码_asp.net utf8 导出中文字符乱码-程序员宅基地

文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码

笔记-编译原理-实验一-词法分析器设计_对pl/0作以下修改扩充。增加单词-程序员宅基地

文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词

android adb shell 权限,android adb shell权限被拒绝-程序员宅基地

文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限

投影仪-相机标定_相机-投影仪标定-程序员宅基地

文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定

Wayland架构、渲染、硬件支持-程序员宅基地

文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland

推荐文章

热门文章

相关标签