参考:《汇编语言》 王爽 第四章
1.一个源程序从写到执行的过程
第一步:编写汇编源程序
第二步:对源程序进行编译连接
第三步:在操作系统中执行
2.源程序
代码:
assume cs:first first segment start: mov ax,2 add ax,ax add ax,ax mov ax,4C00H int 21H first ends end start
代码解释:
assume 、segment、ends、end 等都是伪指令
end 表示 程序结束。
segment与ends(注意与end的区分)成对出现,表示一个段,segment前面的 first 表示段的名字,标号,可以任意取。一个程序至少有一个段。
assume 用来把寄存器跟段关联起来。
start:这个可以随便取名字,但要与end 后面的一样。表示程序的入口。CS:IP 指向。
3.编译连接
(在win7 64位,可能有问题,用DOSBox 模拟)
使用masm编译,link链接
把上面的代码保存到 1.asm中
编译:在cmd中输入 masm 1.asm; 生成 1.obj
链接:在cmd中输入 link 1.obj; 生成 1.exe
4.程序的运行
在cmd中输入1 ,运行不会有任何输出,一闪而过
程序的运行过程:首先必须有一个正在运行的P1程序,将要运行的P2程序从可执行文件中加载进入内存后将CPU控制权交给P2,P2才能运行。P2开始运行后P1暂停运行。当P2运行完毕后,将CPU的控制权交给P1,此后P1继续运行。DOS中运行1.exe P1可以是command,将1.exe加载如内存。command设置CPU的CS:IP z指向程序的第一条指令(即程序的入口),从而使其运行。程序运行结束后,返回command,CPU继续运行command。
前面代码中的:mov ax,4C00H
int 21H
功能就是程序返回
int 跟c英语中的int没有任何关系,表示中断。
5.程序执行过程的跟踪
在cmd中输入:debug 1.exe 即可跟踪运行1.exe
这时输入r查看寄存器信息,可以看到CX存放源程序中指令的长度。
DS跟CS相差0010H,原因:
程序在运行前,DOS系统先找到一个XX:0000H地址,在这段内存区的前256个这个中 创建一个程序段前缀(PSP)的数据区,DOS要利用PSP来和被加载的程序进行通信。从XX:0010H开始将程序装入。
输入t 单步执行,到int 21H时,输入p结束。