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

本文详细介绍了汇编语言程序从编写到执行的完整流程,包括使用文本编辑器创建源程序,通过汇编器和链接器生成可执行文件,以及可执行文件在内存中的加载和执行。此外,还探讨了伪指令、段定义、程序返回、内存单元表示以及Debug工具在程序跟踪中的应用。
摘要由CSDN通过智能技术生成

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  

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值