. : : 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