8086的分段寻址技术学习总结(Segmented Addressing)

计算机最小粒度的数据单位是bit,但是为每个bit都分配地址不仅浪费资源,同时存取效率低。因此转而用8bits(也就是1个字节,1byte)来占用一个地址。

那么16位的地址线能够访问的地址空间大小为216bytes,与之所对应就是在16位的地址线的另一端用了16位的寄存器来驱动16位宽度的寻址地址。

现在的问题时,我们有20根地址线(也就是有220bytes=2Mb的存储空间),却只有16位寄存器时。怎么利用这16位的寄存器(216bytes<220bytes)去访问2Mb的存储空间?

显然一个16位的寄存器只能访问到216bytes,那么两个呢?不得了,可就是216*216bytes=4Gb,这远远大于我们想要访问220bytes大小的存储空间。问题的决解方案就是多加一个寄存器...

下面来看一下使用2个16位的寄存器是如何去访问220bytes的存储空间的。

从上图可以明显的看出:

实际物理地址 = 段地址左移4位 + 段上偏移量

段地址:段地址用于分段寻址的时候定位段的位置。第一个则寄存器用于表示段地址,段地址最多可以有216K个,每段对应的存储空间大小就是216bytes=64Kb。

这时如果有一组大于64Kb的数据或是指令就得占用多个段,也就是所谓的分段储存。虽然段地址理论上可以有216K,但实际上只需要8个(24*216=220)段就足以访问220bytes的储存空间。

而更常用的使用方法是定义了4个段寄存器:

CS(Code segment)指向代码段,代码段用于储存程序的指令;

DS(Data Segment)指向数据段,数据段用于暂存原始数据和处理后的中间结果及最终结果;

SS(Stack Segment)指向堆栈段,堆栈段用于形成堆栈区;

ES(Extra Segment)指向扩展段,扩展段与数据段类似,一般情况下,数据段用于储存局部变量,扩展段用于储存全局变量。

 

转载于:https://www.cnblogs.com/heixiaoke/p/8596967.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值