鱼C论坛

 找回密码
 立即注册
查看: 1896|回复: 6

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

[复制链接]
发表于 2013-1-13 15:11:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
举个例,如10001H,10002H....
按道理说字的内存地址标识形式应该是以低地址表示,如0001H,为啥是10001H呢?
木有问答模块,只能发在这里。请小甲鱼同志解答下,谢谢咯
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-1-13 16:16:39 | 显示全部楼层
甲鱼哥没看到,我来帮你,这个问题很简单,上面的0001H说得是内存地址的偏移地址,10001H则是物理地址,不明白的话这么跟你打比方吧!你要去你朋友家,你知道他住在哪一个镇(首地址),可是你不知道他的具体地址(偏移地址),那么你怎么可能找得到你朋友呢!好像说得有点偏题了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-1-14 10:59:34 | 显示全部楼层
物理地址=段地址*16+偏移地址
10001H=1000H*16+0001
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-1-14 11:55:56 | 显示全部楼层
本帖最后由 lanmo 于 2013-1-14 12:49 编辑

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

评分

参与人数 1鱼币 +2 收起 理由
s0512 + 2 热爱鱼C^_^

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-1-14 13:16:19 | 显示全部楼层
这个小朋友没有好好的看书啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-1-15 10:33:10 | 显示全部楼层
CPU地址总线是20位的,但是他的内部结构如寄存器等最大是16位的,为了能凑成20位的,所以又一个地址加法器(血汗工厂),进行一个约定的地址处理,物理地址= 段地址*16H+偏移地址,这样就合成了一个20位的地址,哈哈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 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     
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-8 00:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表