前段时间有一个汇编的实验,简单的学习了一下汇编语言基本指令的使用格式及具有的功能。包括了安装使用DOSBox、几种常用的指令,编译几个简单的汇编程序、执行程序、查看寄存器····学习了汇编语言的设计过程。

准备工具

所需工具——DOSBox0.74-win32、debug.exe、LINK.EXE、MASM.EXE。

安装DOSBox

  • 这个没什么好说的,直接运行安装即可。然后点击Close。之后运行程序。

1

创建虚拟C盘

1.将debug.exe、LINK.exe、MASM.exe这三个放到某个盘的XXXX文件夹中(我的是放在了d:/test),然后在程序中输入如下命令

mount c d:/test

2

2.输入c:进入虚拟的c盘。然后输入dir确认一下三个程序是不是在其中。返回结果如下。

3

3.在三个程序的同目录下建立一个记事本文件。后缀名为XXX.asm。(我建立的是t2.asm)准备编写第一个汇编程序。

示例汇编程序

问题:假设(AX)=0025H,逻辑左移2位。

code segment
assume cs:code
s:mov ax,0025h
  mov cl,2
  shl ax,cl

  mov ax,4ch
  int 21h
code ends
end s
  • 注意 mov ax,4ch int 21h是程序的退出代码。避免进入死循环。

4.然后在dosbox中输入masm t2.asm。然后多次回车。最后将显示是否有错误。如果有根据错误位置改正后,再次执行命令。直到没有错误为止。回到目录中可以看到生成了T2.OBJ文件。

4

5.然后执行link t2.obj(不区分大小写)多次回车,最后生成t2.exe文件。

5

6.执行debug t2.exe命令。回车。进行调试。输入u命令(各个命令的作用在文末有详细说明)。对机器代码反汇编显示。如下图所示。

6

7.执行g 0007命令。执行程序到地址0007。(为什么到0007?是因为汇编命令执行的时候到0007执行的是上一个地址的命令。0007地址的代码不会执行。)结果如下图。AX=94 这就是程序的最后结果了。

7

下面还有很多简单的练习。步骤都一样。就不一一介绍了。后面将代码折叠起来。有兴趣的话可以试着练一练哦。

汇编程序练习

  • 假设(AX)=3333H,(BX)=1111H,求两者之差,并查看标志寄存器的值

练习一

code segment
assume cs:code
s:mov ax,3333h
mov bx,1111h
sub ax,bx

mov ax,4ch
int 21h
code ends
end s

8


  • 假设(AX)=FFFFH,(BX)=0001H,求两者之和,并查看标志寄存器的值

练习二

code segment
assume cs:code
s:mov ax,0ffffh
mov bx,0001h
add ax,bx

mov ax,4ch
int 21h
code ends
end s
注意:ffffh在汇编中需要写成0ffffh表示成-1;

10


  • 假设(AX)=0035H,(CX)=000FH,求两者进行与运算

练习三

code segment
assume cs:code
s:mov ax,0035h
mov cx,000fh
and ax,cx

mov ax,4ch
int 21h
code ends
end s

9


  • 编程实现将两存储单元的内容互换(假设已知数据段中存入如下数据:[0100]=12H,[0110]=34H)

练习四

code segment
assume cs:code
s:mov al,12h
mov bl,34h
mov ds:[0100h],bl
mov ds:[0110h],al

mov ax,4ch
int 21h
code ends
end s

11


所有命令的作用

R命令

R命令作用:观看和修改寄存器的值。

在提示符“-”下输入以下命令:R。DEBUG将会显示出当前所有寄存器和标志位的状态。

接下来再输入命令RCX。在提示符“:”后输入100。该命令的作用是将寄存器CX的值设置为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 1AF5:100。观看命令执行结果。
  • 方式二:d [起始位置] [结束位置]。DEBUG从起始位置开始一直显示到结束位置。在提示符“-”下执行命令D DS:100
    1FF。观看命令执行结果。
  • 方式三:d [起始位置] [L长度],长度以L参数为标识。DEBUG从起始位置开始显示指定长度的内容。在提示符“-”下执行命令D
    DS:100 L10。观看命令执行结果。

E命令

E命令作用:改变内存单位的内容。

E命令的使用方式为:E [起始位置]。

在提示符“-”下输入以下命令:E 1AF5:100。

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

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命令作用:输入汇编指令。

G命令

G命令作用:执行汇编指令。

G命令的使用方法是:G [=起始地址] [断点地址],意思是从起始地址开始执行到断点地址。如果不设置断点,则程序一直运行到中止指令才停止。

U命令

U命令作用:对机器代码反汇编显示。

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

执行命令U100 10B,观看反汇编结果。该命令的作用是对从100到10B的机器代码进行反汇编。

N命令

N命令作用:设置文件名,为将刚才编写的汇编程序存盘做准备。

W命令

W命令作用:将文件或者特定扇区写入磁盘。

在示例“N命令的使用”中已经实验了如何使用W命令将文件存盘。

  • 在没有很好地掌握汇编语言和磁盘文件系统前,暂时不要使用W命令写磁盘扇区,否则很容易损坏磁盘文件,甚至破坏整个磁盘的文件系统。

L命令

L命令作用:从磁盘中将文件或扇区内容读入内存。

将文件调入内存必须先用DEBUG的N命令设定文件名。

T命令

T命令作用:执行汇编程序,单步跟踪。

T命令的使用方式是T [=地址] [指令数]。如果忽略“地址”的话,T命令从CS:IP处开始运行。“指令数”是要单步执行的指令的数量。

P命令

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

P命令的使用方式与T命令的使用方式完全相同。

I命令

I命令作用:从计算机输入端口读取数据并显示。

I命令的用法是I [端口地址]。例如从3F8号端口读取数据并显示的命令为:I 3F8。

O命令

O命令作用:向计算机输出端口送出数据。

O命令的用法是O [端口地址] [字节值]。例如向278号端口发出数据20H的命令为:I 278 20。

Q命令

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

最后修改:2018 年 11 月 03 日 08 : 34 PM
生活需要一些仪式感,比如手冲一杯咖啡:)