资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

汇编语言4,5章学习笔记-创新互联

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

成都创新互联科技有限公司专业互联网基础服务商,为您提供服务器托管高防主机,成都IDC机房托管,成都主机托管等互联网服务。

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

编写~编译连接~执行

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  

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


分享标题:汇编语言4,5章学习笔记-创新互联
文章起源:http://cdkjz.cn/article/dpgddp.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220