这章算是一个实践部分把,写 了一个汇编程序,并用debug去跟踪每条指令的进程,看寄存器和内存的变化,算是对之前的一个小总结把
4.1 源程序到执行的过程
一个汇编程序写好,要编译成目标文件,文件后缀是obj的,再链接形成exe后缀的,再接着去执行
4.2 源程序
直接上图把
伪指令由编译器执行,汇编指令由CPU执行
assume是伪指令,关联段寄存器和程序中用segment and end代表的段关联
segment 和ends表示段的开始和结束
end表示整个程序结束
另外程序会有个叫程序返回的东西
如p2要运行的话,必须之前有个P1在运行中,P1把p2扔到内存中,把CPU控制权给P2,p2运行完了,cpu控制权还给P1。这就叫程序返回
最后2条指令
mov ax,4c00h
int 21h
就是实现程序返回的。具体为啥我也不知道,死记住了
4.3 写源程序
1.asm
4.4 编译
1.asm->1.obj
4.5链接
1.obj->1.exe
4.6 简化编译和链接到同一步骤
前面的编译和链接书上是分别用微软的masm5.0和linker3.6
但我的是64位的机子,跑步起来
就用了dosbox
放链接
http://download.csdn.net/download/wy4649/5536047
里面有教程
点运行,可以直接完成编译和链接的过程,生成1.exe文件
4.7运行跟踪
用debug去一步步跟踪1.exe的执行
截图放个最后程序运行的情况
另外,最后一条语句执行的时候要用P去执行,而不是t。具体不是很清晰,P大概是代表一个程序的结束把,防止debug再跟踪下面和程序无关的指令把
这章一定要自己动手敲敲敲敲,敲了N久才理解了~~~~~~
还有折腾DOSBOX也花了不少时间
就先这样把。晚安~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
EOF