错误认识:
内存被划分成了一个一个的段,每一个段有一个段地址。
其实:
内存并没有分段,段的划分来自于CPU,由于8086CPU用“ 段地址*16 + 偏移地址 = 物理地址 ”的方式给出内存单元的物理地址,使得我们可以用分段的方式来管理内存。
在编程时可以根据需要,将若干地址连续的内存单元看成一个段,用段地址*16定位段的起始地址(基础地址),用偏移地址定位段中的内存单元。
1、段地址 * 16 必然是16的倍数,所以一个段的起始地址也一定是16的倍数;
2、偏移地址为16位,16位地址的寻址能力为64K,所以一个段的长度最大为64K。
结论:CPU可以用不同的段地址和偏移地址形成同一个物理地址。
如果给定一个段地址,仅通过变化偏移地址来进行寻址,最多可以定位多少内存单元?
偏移地址16位,变化范围为0~FFFFH,仅用偏移地址来寻址最多可寻64K个内存单元。
比如:给定段地址1000H,用偏移地址寻址,CPU的寻址范围为:1000H~1FFFFH。
数据在21F60H内存单元中,对于8086PC机的两种描述:
1、数据存在内存2000:1F60单元中;
2、数据存在内存的2000段中的1F60H单元中。
可根据需要,将地址连续、起始地址为16的倍数的一组内存单元定义为一个段。