编写一个完整的汇编语言
- 汇编语言由2类指令组成:
- 汇编指令 :有真实对应的机器指令,编译时可以被编译为机器指令,最终被CPU执行,如 mov、add、sub 等
- 伪指令:没有真实对应的机器指令,由编译器解析,最终不被CPU执行,如 assume、segment、ends、end 等
-
汇编的注释以分号开头
;--- 数据段 --- data segment string db 'Hello World!$' data ends
-
汇编代码示例
assume cs:code code segment mov ax,1122H mov bx,3344H add ax,bx mov ah,4cH int 21H code ends end
伪指令(assume,segment,ends,end)
-
assume:将汇编代码中定义的某个段与CPU中的某个段寄存器关联起来。比如,将用作代码段的code段和CPU中的CS寄存器关联起来,assume的作用是将一个段的地址设置给一个段寄存器
-
segment 和 ends 的作用是定义一个段,segment 代表一个段的开始,ends 代表一个段的结束,使用格式为
段名 segment ; 段的内容 段名 ends
-
end:编译遇到end时,就结束对源程序的编译
-
一个有意义的汇编程序中,至少要有一个段作为代码段存放代码
退出汇编程序
-
下面2句代码的作用是退出程序
; 写法一 mov ah, 4cH int 21H ; 写法二 mov ax, 4c00H int 21H
中断
- 中断是由于软件的或硬件的信号,使得CPU暂停当前的任务,转而去执行另一段子程序。也就是说,在程序运行过程中,系统出现了一个必须由CPU立即处理的情况,此时,CPU暂时终止当前程序的执行转而处理这个新事件的过程就叫做中断。
- 中断的分类
- 硬中断(外中断):由外部设备(比如网卡、硬盘)随机引发的。比如,当前网卡收到数据包的时候,就会发出一个中断
- 软中断(内中断):由执行中断指令产生的,可以通过程序控制触发
从本质上来讲,中断是一种电信号,当设备有某种事件发生时,它就会产生中断,通过总线把电信号发送给中断控制器。
如果中断的线是激活的(中断处于打开的状态),中断控制器就把电信号发送给处理器的某个特定引脚。处理器接收到中断信号后,立即停止自己正在做的事,跳到中断程序的入口点,进行中断处理。
- 中断过程示例图
- 可以通过 int n 产生中断(其中 int 是 interrupt 的意思)
n是中断码,内存中有一张中断向量表,用来存放中断码对应的中断处理程序的入口地址
CPU在接收到中断信号后,暂停当前正在执行的程序,跳转到中断码对应的中断向量表的中断向量指向的地址处,去执行中断处理程序 - 常见中断(中断向量表)
int 10H :用于执行BIOS中断
int 3 :是"断点中断",用于调试程序。我们在调试程序时,为特定行的代码打上断点,实质上是在内存中,该代码对应的机器指令处,插入了 int 3 调用。
int 21H :用于执行DOS系统功能调用,AH寄存器存储功能号
DOS系统功能调用
-
DOS系统功能调用(DOS系统功能调用表,INT-21H):由DOS提供的一组实现特殊功能的子程序,供程序员在编写自己的程序时调用,以减轻编程的工作量,涉及屏幕显示、文件管理、I/O管理等等。每个子程序都有一个功能号,所有的功能调用的格式都是一致的。调用的步骤大致如下:
1.系统功能号送到寄存器AH中
2.入口参数送到指定的寄存器中
3.用 int 21H 指令执行功能调用
4.根据出口参数分析功能调用执行情况;----定义数据段---- data segment string db 'Hello World!$' data ends mov ax, data mov ds, ax ; 将data设置给ds寄存器,即将data设置为数据段 mov ah, 9H ; 功能号9H代表在屏幕显示字符串 mov dx, offset string ; ds:dx代表字符串地址 int 21H ; 执行DOS系统功能调用
emu8086常用快捷键
- F5:调试运行
- F4:重新加载
- F8:下一步(单步执行)
- F9:直接一步到位运行整个程序
- Ctrl + F8:跳过前面代码,断点到单击选中的代码那行