一个汇编语言程序从写出到最终执行的过程为:
源文件(.asm)------>编译(.obj)------->连接(.exe)------>加载------>内存中的程序------>执行。
下面看个简单的汇编语言源程序:
assume cs:codesg 将段寄存器cs与程序中的某一个段(这里是代码段codesg)想关联
codesg segment 定义一个段(这里是代码段)
start: mov ax,0123H
mov bx,0456H
add ax,bx
add ax,ax
mov ax,4c00H 这两句的作用是程序返回,即把cpu的控制权交还给dos
int 21H
codesg ends 代码段到此结束
end 标记整个程序结束
上面这段程序只包含了代码段的内容,大家都知道在汇编程序里应该要包含数据段、代码段、堆栈段
下面给出一个简单的汇编源程序框架:
(来自RadAsm软件自动生成的汇编程序)
dos系统中.exe文件中的程序的加载过程:
程序加载后,ds中存放着程序所在内存区的段地址,这个内存区的偏移地址为0,即程序所在内存区的地址为ds:0
这个内存区的前256个字节中存放的是PSP,dos用来和程序进行通信,从256个字节后的空间存放的是程序,程序的物理地址为:
SA*16+0+256=(SA+16)*16+0 这个是10进制的
所以物理地址为SA+10:0 这才是标准的16进制表示