【学习笔记】6.包含多个段的程序

本文详细探讨了如何在代码段中使用数据和栈,并讲解了如何将数据、代码和栈分别放入不同的段。通过这种方式,可以更好地管理和优化程序的内存布局,提高执行效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

包含多个段的程序

在需要获得一段安全的空间来存放数据/代码时,往往需要在操作系统的环境中,合法地通过操作系统取得空间。在操作系统允许的情况下,程序可以取得任意容量的空间。
程序取得所需空间的方法有两种,一是在加载程序的时候为程序分配,再就是程序在执行过程中向系统申请。暂且不讨论第二种方法。
使用多个段时,通常将数据、代码、栈放入不同的段之中。

6.1 在代码段中使用数据

若把代码段看作一个函数,那么函数题中也可以声明所需要用到的数据(类比C语言),但是,如此一来的话数据与代码相连存储,那么数据会被编译器视作代码,显然这不是我们希望看到的。
那么如何避免这个问题呢?
我们可以对程序的入口,即第一条可执行代码进行标号,通常标记为start。而程序的执行过程是从CS:IP(程序指定或者默认)地址处开始执行每一条代码,那么我们只需要将其设置为我们需要的程序入口处即可。在代码段尾部由“end start”指明的程序入口,被转化成一个入口地址,存储在可执行文件的描述信息中。
有了这种方法,可以这样来安排程序的框架:

assume cs:code

code segment
:
:
数据
start:
代码
code ends

end start

6.2 在代码段中使用栈

由于栈数据结构用来存储数据,那么相当于在代码段之中开辟一段空间来存放栈,即:
声明一连串的数据,以在内存中占据一定的空间,将这段空间的首地址传递给ss段寄存器,计算初始栈顶地址以传递给sp寄存器。那么就完成了段的声明。
【注意】
使用此方法应注意数据类型(字or字节...),以及应时刻注意栈顶是否越界的问题,否则容易引发数据丢失问题。

6.3 将数据、代码、栈放入不同的段

在代码段中使用数据、栈有两个问题:
(1)程序显得十分混乱
(2)在16位实模式下,一个段的长度不能超过64(2^16)kb,那么当数据、代码、栈需要的空间大于64KB时,显然不能再存放在一个段里。

为了解决这个问题,很自然的想法就是分开多个段,首先想到的就是数据、栈、代码各一个段。
所以可以按照下面的格式书写代码:

assume cs:code,da:data,ss:stack

data segment
......数据,,,,,,
data ends

stack segment
......声明栈空间......
stack ends

code segment
start:
......代码......
code ends

end start

【注意】
1.data、stack、code均为我们自定义的标号,可以另外选择名称,但一旦确定之后,编译器就为他们赋值为相应段的首地址。
2.assume cs:code,da:data,ss:stack是伪指令,由编译器执行,只是在源程序中存在的信息,CPU并不知道。所以如果想要将cs,ds,ss指向相应的首地址,需要将地址传送到段寄存器之中。
3.8086CPU不允许将一个数值直接送入段寄存器中,那么只有通过送入寄存器间接送入,如下:
mov ax,stack
mov ss,ax
mov sp,20h





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值