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

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

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

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

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

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

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

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

从上图可以明显的看出:

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

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

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

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

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

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

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

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

上一篇:JavaSE回顾及巩固的自学之路(一)——————前言


下一篇:ae 地理坐标与投影坐标转换 [转]