汇编语言——物理地址=段地址x16+偏移地址,检测点2.2

1、为何 物理地址=段地址x16+偏移地址?

 

  PS:刚开始学时,我都笨到不明白为何是2的N次方,咱把物理地址就当数字,计算机中数字是由不少位0或1自由组合的, 而每一位上要么是0要么是1,只有这两种状况,因此N位就能够组成2的N次方个编号地址了spa

  8086CPU的地址总线是20条(位),所以就能够给104 8576个(1M)内存单元进行地址编号,而寄存器和数据总线都是16位的,16位对应6 5536(64K),这样就浪费了好多好多内存空间啊,咋办?因而那些聪明人整了个地址加法器,地址加法器干的活计就是把16位的段地址乘以16,为啥非得是16呢?我让你干件事:你把数字68左移一位是多少,你告诉我680,没错,你把68后面补个0 其实就是乘以了10,我再让你把十六进制38H左移一位你仍是像刚才那么干在后面补个0是380H,其实仍是乘以了10H, 而这里的10H对应十进制16,1位十六进制对应4位二进制,因此段地址乘以十进制的16,就是至关于在一个16位的二进制数后面补了4个0,哇这不就凑成了20位,内存就避免了浪费,乘完16获得了一个首地址(起始地址/基础地址),把首地址做为一个起始地址加上一个16位二进制偏移地址,偏移地址的偏移量是0H~FFFFH(由于16位二进制数最大是FFFFH),因此段空间最大是64K(FFFFH),咱们之后就能够根据须要逻辑上把内存分段进行内存空间的访问。blog

2、段地址x16是一个16的倍数

一看标题这不废话吗。。。直到看到王爽老师《汇编语言》检测点2.2,加深了对这句话的理解内存

咱们就作最小为多少,根据公式很容易想到,当偏移地址最大为FFFFH时 段地址SA确定最小啊io

①SAx16+FFFFH=20000H基础

②SAx16=20000H-FFFFH=10001H百度

③SA=10001H/16(10H)=1000H二进制

这也太简单了吧,百度下看看答案对不对,纳尼答案咋是1001H,哪来的啊?我算错了???算了好几回都是1000H啊,咋回事?float

  咱们注意SAx16=20000H-FFFFH=10001H,咱们再看一眼标题二,10001H=65537 显然不是16的倍数啊,而后咱们就把以前用的FFFF换成FFFF-1,FFFF-2,FFFF-3...直到试到FFFF-F=FFF0H时获得了16的倍数和正确答案吻合了。但这样操做好累啊,一个一个试,因此快速的作法是反过来想:我要保证首地址是一个16的倍数,从十六进制角度看就是要保证末尾是个0,im

因此20000H-?=末尾是0的数,显然FFF后面带个0就能跟20000H末尾的0对应相减获得末尾是0的数。
d3

  总结:内存中有些内存单元不能做为段的首地址(段地址x16),由于有些物理地址不是16(10H)的倍数,可是段地址能够是任何地址由于它要乘16,不管地址是多少均可以,注意我这里说的段地址并非内存中的地址,由于段地址是16位,内存的物理地址是20位,前面说的首地址(在偏移为0的状况下)能够当作内存中段的起始物理地址,但这不表示那些不能作首地址的内存单元访问不到,由于一个内存单元的物理地址能够根据段地址和偏移地址有不少种组合来访问它。

如有错误,请评论指正,谢谢!

相关文章
相关标签/搜索