. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->寄存器(CPU工作原理)
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  为什么两个十六位寄存器经过地址加法器后变成20位的物理地址?  [待解决] 回复[ 7次 ]   点击[ 671次 ]  
yiday
[帖 主]   [ 发表时间:2009-10-09 09:40 ]   [引用]   [回复]   [ top ] 
荣誉值:5
信誉值:0
注册日期:2009-09-24 17:56
为什么不是32位?
tinyparticle
[第1楼]   [ 回复时间:2009-10-09 20:54 ]   [引用]   [回复]   [ top ] 
荣誉值:188
信誉值:4
注册日期:2009-07-05 19:26
参阅书P21页 图2.7地址加法器的工作过程 和 2.7节物理地址公式
tanyouf
[第2楼]   [ 回复时间:2009-10-30 08:05 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2009-09-01 14:59
书里p20-p23页很详细的讲解了8086CPU给出物理地址的方法,楼主可以学习下。
scuzg
[第3楼]   [ 回复时间:2009-11-01 19:38 ]   [引用]   [回复]   [ top ] 
荣誉值:307
信誉值:0
注册日期:2009-03-15 23:46
也可阅读这段博文:

http://www.asmedu.net/blog/user/postcontent.jsp?neighborId=19481&kindId=34937&postId=42062&readSg=1
aibaodong1
[第4楼]   [ 回复时间:2009-11-03 11:57 ]   [引用]   [回复]   [ top ] 
荣誉值:7
信誉值:0
注册日期:2009-10-26 16:27
1个16寄存器作为段地址,1个16寄存器作为偏移地址!!
而物理地址=段地址*16+偏移地址!
也可以这么理解段地址(2进制的)后面添4个0再加上偏移地址(2进制)
例:cs=1015H,ip=5614h则物理地址=00010000000101010000
                                   0101011000010100
----------------------------------------------------
                               00010101011101100100=15764h 
              段地址(16进制)后面添1个0再加上偏移地址(16进制)
例:(用上面的数据)      物理地址=10150
                                5614
------------------------------------------
                               15764h
希望你能看懂!!!!!!!!!
aibaodong1
[第5楼]   [ 回复时间:2009-11-03 11:58 ]   [引用]   [回复]   [ top ] 
荣誉值:7
信誉值:0
注册日期:2009-10-26 16:27
补充上面的回答!!!正好是20位!!!!!!!!!
suixin
[第6楼]   [ 回复时间:2009-12-01 09:46 ]   [引用]   [回复]   [ top ] 
荣誉值:7
信誉值:10
注册日期:2009-11-19 11:28
因为地址线只有20条
wojiaokangyi
[第7楼]   [ 回复时间:2010-04-02 22:34 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-03-27 14:42
不是单纯的累加而是互补不足
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved