. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->寄存器(CPU工作原理)
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  关于读取指令的疑问  [待解决] 回复[ 3次 ]   点击[ 283次 ]  
wangy_neu
[帖 主]   [ 发表时间:2010-12-01 19:38 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-11-30 15:22
CPU在读取CS:IP指向的内存地址中的指令时,怎么知道读取多少字节?
    比如书上第24页,内存20000-20002的内容为B8 20 01,代表的指令是mov ax,0123H,
    当CS为2000H,IP为0000H时,为什么读的是3位而不是2位?
    书上有讲,在内存中指令和数据没有任何区别,都是二进制信息。那CPU是根据什么决定读取的数据长度呢?
rebelsky
[第1楼]   [ 回复时间:2010-12-02 16:51 ]   [引用]   [回复]   [ top ] 
荣誉值:3
信誉值:0
注册日期:2010-09-13 09:09
存储器可以分为若干个存储单元,每个存储单元可以存储8各二进制位,也就是1各字节,b8 20 01 存储在三个内存单元中,所以是3各字节,这个在第一章,存储单元里面讲到了的...
515332695
[第2楼]   [ 回复时间:2010-12-02 20:12 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-06-01 22:23
我认为是根据指令的类型吧,B8表示像寄存器ax中传数据,所以是3个字节。
vipman
[第3楼]   [ 回复时间:2010-12-29 15:15 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-12-23 10:18
我想可能是这样的:指令在内存中存在是以数据的形式存在的,但不同的指令定义和数据不同,比如MOV ax,**,mov ax,操作数为数据时的指令就是B8,mov ax,bx,mov ax操作数为寄存器时为89,长度都为1字节,后面的具体是看下一个指令操作的是什么!立即数(数据)为两个字节,寄存器为一个字节。mov 不同的寄存器,机器码(指令代码)不相同。
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved