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元起,快前往官网查看详情吧