第四章 第一个程序
4.2 源程序
程序4.1
assume cs:codesg
codesg segment
start: mov ax,0123H
mov bx,0456H
add ax,bx
add ax,ax
mov ax,4C00H
int 21H
codesg ends
end
1.伪指令
在汇编语言程序中,包含两种指令:汇编指令和伪指令。汇编指令是有对应的机器码的指令,可以被编译为机器指令,最终为CPU所执行。而伪指令没有对应的机器指令,最终不被CPU锁执行。伪指令是由编译器来执行的指令,编译器根据伪指令来进行相关的编译工作。(伪指令实际为代码中的“标记”。)
程序4.1中出现了三种伪指令:
(1) XXX segment
:
XXX ends
segment 和ends是一对成对使用的伪指令,这是在写可被编译器编译的汇编程序时,必须要用到得一对伪指令。segment 和ends的功能是定义一个段,segment 说明一个段的开始,ends说明一个段的结束。一个段必须有一个名称来标识,使用格式:
段名 segment
:
段名 ends
如,程序4.1中的 codesg 即为段名,这个段从此开始。
一个汇编程序是由多个段组成的,这些段被用来存放代码、数据或当作栈空间来使用。我们在以前讲的段的概念,在汇编源程序得到了应用与体现,一个源程序中所有将被计算机处理的信息: 指令、数据、栈,被划分到了不同的段中。
一个有意义的汇编程序中至少要有一个段,这个段用来存放代码。
(2) end
end 是一个汇编程序的结束标记,编译器在编译汇编程序时,如果碰到了伪指令 end,就结束对源程序的编译。若程序写完了,要在结尾处加上伪指令 end。否则,编译器在编译时,无法知道程序在何处结束。
注意,不要搞混了end 和 ends,ends 是和 segment 成对使用的,标记一个段的结束,ends 的含义可理解为“end segment”
(3) assume
这条伪指令的含义为“假设”。它假设某一段寄存器和程序中的某一个用segment...ends定义的段相关联。通过assume说明这种关联,在需要的情况下,编译程序可以将段寄存器和某一个具体的段相联系。assume简单理解,是将有特殊用途的段和相关的段寄存器关联起来。
如程序4.1中,我们用 codesg segment... codesg ends 定义了一个名为 codesg的段,这个段中我们存放代码,所以这个段是一个代码段。我们在程序的开头,用assume cs:codesg 将用作代码段的段codesg和CPU中的段寄存器cs联系起来。
2. 源程序中的“程序”
我们可以讲源程序文件中的所有内容成为源程序,将源程序中最终由计算机执行、处理的指令或数据,称为程序。程序最先以汇编指令的形式存在源程序中,经编译、连接后转变为机器码,存储在可执行文件中。
3. 标号
汇编源程序中,除了汇编指令和伪指令外,还有一些标号,比如“codesg”。一个标号指代了一个地址。比如codesg在segment的前面,做为一个段的名称,这个段的名称最终将被编译、连接程序处理为一个段的段地址。‘
4. 程序的结构
程序4.2
assume cs:abc
abc segment
mov ax, 2
add ax, ax
add ax, ax
abc ends
end
5. 程序返回
我们的程序最先以汇编指令的形式存在源程序中,经编译、连接后转变为机器码,存储在可执行文件中,那么,它怎样得到运行呢?
我们在DOS(一个单任务操作系统)的基础上,简单说明:
一个程序P2在可执行文件中,则必须有一个正在运行的程序P1,将P2从可执行文件中家载入内存后,将CPU的控制权交给P2,P2才能得以运行。P2开始运行后,P1暂停运行。而当P2运行完毕后,应该将CPU的控制权交还给使它得以运行的程序P1,此后,P1继续运行。
现在,我们知道,一个程序结束后,将CPU的控制权交还给使它得以运行的程序,我们称这个过程为:程序返回。 那么,如何返回呢?应该在程序的末尾添加返回的程序段。
我们回过头来,看下程序4.1中的两条指令:
mov ax, 4c00H
int 21H
这两条指令所实现的功能就是程序返回。
目前为止,我们已经遇到了几个和结束有关的内容: 段结束、程序结束、程序返回。如下:
目的
相关指令
指令性质
指令执行者
通知编译器段结束
段名 ends
伪指令
编译时,由编译器执行
通知编译器程序结束
End
伪指令
编译时,由编译器执行
程序返回
Mov ax,4c00H int 21H
汇编指令
执行时,由CPU执行
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/syf442/archive/2009/08/06/4419265.aspx