. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->寄存器(CPU工作原理)
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  CPU读取数据长度的疑问  [已解决] 回复[ 3次 ]   点击[ 355次 ]  
xohome
[帖 主]   [ 发表时间:2010-11-24 11:20 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:2
注册日期:2010-11-24 11:04
CPU的寻址一次读取的数据是目标地址单元内的数据么?长度是多少?有什么约束?
我看书上一次性读入了3个单元的数据,为什么读取地址20000H内的数据会将20000H - 20002H内的数据全部读入?
我原先的理解是一次性只读入一个内存单元(1Byte)的数据,然后将读入的指令存入指令缓冲器,等一条指令读取完了再执行,但明显错了。书上CS:IP=2000:0000 目标地址为20000H, 可一次性读了20000H - 20002H内的数据 十六进制为:B82301 长度为3Byte。  可有时候又只读了两个内存单元 20008H - 20009H 的数据 。到底这个长度是根据什么来确定的?
xohome
[第1楼]   [ 回复时间:2010-11-24 12:08 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:2
注册日期:2010-11-24 11:04
是不是题目只是抽象的,目的为了描述CPU寻址取值的过程?  因为CPU一次读入的数据量应该和CPU位数是一样的吧 !
xohome
[第2楼]   [ 回复时间:2010-11-24 12:52 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:2
注册日期:2010-11-24 11:04
搜索了相关的资料,一次性读入数据大小为16位 而指令是根据指令长度来确定
xohome
[第3楼]   [ 回复时间:2010-11-24 12:52 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:2
注册日期:2010-11-24 11:04
此贴由 贴主 于 [ 2010-11-24 12:52 ] 结贴。 结贴原因:问题已解决
得分情况:
此问题已结贴!
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved