韩正奇 发表于 2013-1-13 15:11:09

小甲鱼,字的单元地址表示形式为啥是这样的

举个例,如10001H,10002H....
按道理说字的内存地址标识形式应该是以低地址表示,如0001H,为啥是10001H呢?
木有问答模块,只能发在这里。请小甲鱼同志解答下,谢谢咯

属専色灰 发表于 2013-1-13 16:16:39

甲鱼哥没看到,我来帮你,这个问题很简单,上面的0001H说得是内存地址的偏移地址,10001H则是物理地址,不明白的话这么跟你打比方吧!你要去你朋友家,你知道他住在哪一个镇(首地址),可是你不知道他的具体地址(偏移地址),那么你怎么可能找得到你朋友呢!好像说得有点偏题了。

54085256 发表于 2013-1-14 10:59:34

物理地址=段地址*16+偏移地址
10001H=1000H*16+0001

lanmo 发表于 2013-1-14 11:55:56

本帖最后由 lanmo 于 2013-1-14 12:49 编辑

上面两位正解。你可以返回去再看看2.4物理地址,8086CPU有20位地址总线,可传送20位,而其内部结构只能传送16位地址,因此用了采用一种在内部用两个16位地址合成的方法来形成一个20位的物理地址(传说中的地址加法器),也即表示“物理地址=段地址*16+偏移地址“

NGtailang 发表于 2013-1-14 13:16:19

这个小朋友没有好好的看书啊

林之白狼 发表于 2013-1-15 10:33:10

CPU地址总线是20位的,但是他的内部结构如寄存器等最大是16位的,为了能凑成20位的,所以又一个地址加法器(血汗工厂),进行一个约定的地址处理,物理地址= 段地址*16H+偏移地址,这样就合成了一个20位的地址,哈哈{:5_109:}

jeset 发表于 2013-1-17 09:33:40

8086中的通用寄存器是16位,而一个字节等于8位,一个字等于两个字节。小甲鱼老师的课程中已经说明了,因为8086的CPU是16位,而外部的地址总线为20位,16位是完全不能合理利用20位的地址总线,那么在CPU内部就发明了一个地址加法器。格式就是为3楼的说法,*16就是16进制的一个10,16进制是0-F一个进位。

物理地址=段地址*16+偏移地址
10001H=1000H*16+0001   
页: [1]
查看完整版本: 小甲鱼,字的单元地址表示形式为啥是这样的