汇编语言4,5章学习笔记

  • Post author:
  • Post category:其他



4.1一个源程序从写出到执行的过程




一个汇编语言程序从写出到最终执行的简要过程:




编写~编译连接~执行

1、

编写

:使用文本编辑器(如记事本、nodepad++、UltraEdit等),用汇编语言编写汇编

源程序。


2、对源程序编译连接

:使用汇编语言编译程序(MASM.EXE)对源程序文件中的源程序进行编译,  产生目标文件;再用连接程序(LINK.EXE)对目标文件进行连接,生成可在操作系统中直接运行的

可执行文件





可执行文件

包含两部分内容:


程序(从源程序中的汇编指令翻译过来的机器码)和数据(源程序中定义的数据)


相关的描述信息(比如:程序有多大、要占多少内存空间等)


3、执行可执行文件中的程序:

操作系统依照可执行文件中的描述信息,将可执行文件中的机器码和数据加载入内存,并进行相关的初始化(比如:设置CS:IP指向第一条要执行的指令),然后由cpu执行程序。


4.2源程序


汇编指令

有对应的机器码的指令,可以被编译成机器指令,最终为cpu所执行。


伪指令

没有对应的机器码的指令,最终不被cpu所执行。是由编译器来执行的指令,编译器根据                 伪指令来进行相关的编译工作。

定义一个段

segment和ends

是成对使用的伪指令,在写被编译器编译的汇编程序时,必须要用                         到的一对伪指令,其功能是定义一个段,segment说明一个段开始,ends说明一个                         段结束。

(一个段必须有一个名称来标识,使用格式为:段名 segment    段名 ends)

一个汇编程序由多个段组成,这些段被用来存放代码,数据,或当作栈空间来使用。



end是一个汇编程序的结束标记


assume

含义为假设 其假设某一段寄存器和程序中的某一个用segment



ends定义的段相关联。




源程序中的“程序”


汇编源程序:

伪指令(编译器处理)

汇编指令(编译为机器码)

程序:源程序中最终由计算机执行、处理的指令或数据。





标号


一个标号指代了一个地址

codesg:放在segment的前面,作为一个段的名称,这个段的名称最终将被编译、连接程序处理为一个段的段地址。

一个程序结束后,将cpu的控制权交还给使它得以运行的程序,我们称这个过程为:

程序返回



应该在程序末尾添加返回的程序段。



mov ax,4c00H



int 21H



这两条指令所实现的功能就是程序返回

段结束 程序结束 程序返回


编译和连接

连接的作用:

当源程序很大时,可以将它分为多个源程序文件夹来编译,每个源程序编译成为目标文件后,再     用连接程序将他们连接到一起,生成一个可执行文件;

程序中调用了某个库文件中的子程序,需要将这个库文件和该程序生成的目标文件连接到一起,     生成一个可执行文件。

一个源程序编译后,得到了存有机器码的目标文件,目标文件中有些内容不能直接用来生成执行     文件,连接程序将这些内容处理为最终的可执行文件。


4.8可执行文件中的程序装入内存并运行的原理

1.exe的执行过程:

(1)我们在提示符”G:\TRY“后面输入可执行文件的名字”1“,按enter键。

(2)1.exe中的程序运行;

(3)运行结束,返回,再次显示提示符”G:\TRY”。

操作系统的外壳shell

汇编程序从写出到执行的过程:


4.9程序执行过程的跟踪

debug可以将程序加载入内存,设置CS:IP指向程序的入口,但debug并不放弃对cpu的控制,这样,我们就可以使用debug的相关命令来单步执行程序,查看每条指令的执行结果。


程序加载后,ds中存放着程序所在内存区的段地址,这个内存区的偏移地址为0,则程序所在的内存区的地址为:ds:0;


这个内存区的前256个字节中存放的是PSP,dos用来和程序进行通信。


从256字节处向后的空间存放的是程序。


所以 PSP的段地址SA,偏移地址为0,物理地址为SA*16+0.。

要使用P命令执行int21。


5.1[bx]

[bx]和[0]有些类似,[0]表示内存单元,它的偏移地址是0.

(1)内存单元的地址:

(2)内存单元的长度。

我们用[0]表示一个内存单元时,0 表示单元的 偏移地址,段地址默认在ds中,单元的长度 (类型)可以由具体指令中的其他操作对象 (比如说寄存器)指出如前边的AX.AL。

[bx]同样也表示一个内存单元,它的偏移地址在bx中,比如下面的指令:

mov ax,[bx]

mov al, [bx]

loop循环

描述性符号()


pop ax

(ax)=((ss)*16+(sp))

(sp)=(sp)+2


idata表示常量

mov ax,[bx] 功能:bx中存放的数据作为一个偏移地址 EA ,段地址SA 默认在ds中,将SA:EA处 的教据送入ax中

即(ax)=(ds*16+(bx))


5.2loop

指令的格式是:loop标号,CPU 执行loop指令的时候,要进行两步操作:

1、(cx) =(cx)-1

2、 判断cx中的值,不为零则转至标号处执行程序,如果为零则向下执行。

通常用loop实现循环功能,cx中存放循环次数

mov cx,循环次数

s:

  循环执行的程序段

  loops

利用加法计算123*236

assume cs:code
code segment
  mov ax,0
  mov cx,236
s:add ax,123
 loop s

mov ax,4c00h
int 21h
code ends
end


5.3在debug中跟踪用loop指令实现的循环程序

苜先,将其编辑为源程序文件,文件名 定为 p3.asm:对其进行编译连接后生成 p3.exe:然后西用Debug对p3.exe中的程序进行跟踪。


5.5loop和[bx]的联合应用

计算ffff:0~ffff:b单元中的数据的和,结果存储在dx中。

(1)运算后的结果是否会超出dx 所能存储的范围?



ffff0~ffffb内存单元中的数据是字节型数据,范围在0~255之间,12个这样的数据相加,结果不会大于 65535,可以在dx中存放下。

(2)是否能将量0~ffffb中的数据直接累加到dx?



不行,因为量:0~ffffb中的数据是8位 的,不能直接加到16位寄存器dx中


5.7一段安全的空间

在8086模 式中,随意向一 段内存空间写入内容是很危险的,因为这段空间中可能存放着重要的系统数据或代码。

比如下面的指令:

mov ax.1000h

mov ds.ax

mov al.0

mov ds:[0],al



版权声明:本文为m0_74241276原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。