注册 登录
编程论坛 汇编论坛

cpu怎么知道一次应该从内存里面取几个字节?

wobianlong 发布于 2012-08-06 16:31, 801 次点击
有些指令占据内存是3位 4,5 位不尽相等
楼主不清楚真的的指令集,
现在有B8 23 01=MOV AX,0123H
b8 22 66=mov ax,6622
8B D8=MOV BX,AX
楼主想问的问题是 CPU是如何知道 2个字节是一个指令,或者3个字节是一个指令又或者4个字节是一个指令的,
如果遇见这个的问题,取3个字节会形成一个指令,取4个字节也会形成一个指令,怎么避免这样情况呢?
楼主YY得到的是假设有BABABA 这个指令,那么就不会有BABABA*****类似的指令出现,这样对吗?
还请大家指导啊
9 回复
#2
zklhp2012-08-06 16:36
CPU里面有个解码器 把指令解码然后做相应的东西

楼主想问的问题是 CPU是如何知道 2个字节是一个指令,或者3个字节是一个指令又或者4个字节是一个指令的,

对啊 这就是解码器的工作

取3个字节会形成一个指令,取4个字节也会形成一个指令,怎么避免这样情况呢?

指令的构造有一定的规则 在定的时候已经考虑这个了罢 不大可能会出现这个问题 具体情况请看intel的指令手册
#3
wobianlong2012-08-06 16:48
明白了,请问这个问题你是怎么知道的啊,看的什么书啊
#4
zklhp2012-08-06 17:10
其实最权威的是intel的手册 看那个比看神马书都好 我就是看过指令手册 其他都没看过
#5
wobianlong2012-08-06 17:49
以下是引用zklhp在2012-8-6 17:10:30的发言:

其实最权威的是intel的手册 看那个比看神马书都好 我就是看过指令手册 其他都没看过

看手册什么的感觉很枯燥,真看不懂啊,看不进去
#6
zklhp2012-08-06 18:07
对啊 又不是全看 找你感兴趣的看看呗 比如 指令的构成规则 也就是你感兴趣的

只有本站会员才能查看附件,请 登录

看着一块 你自然知道指令大概怎么构成的了 也就能解答你的疑惑了
#7
zklhp2012-08-06 18:09
如果你想知道更底层的 硬件实现 那你应该看有关CPU设计 实现原理 等的书 不过这种书我没看懂 呵呵 也不好说了

祝好运

没问题记得结题
#8
bingghost2012-08-07 12:11
Opcode    Opcode
#9
洪荒一鼎2012-08-20 09:30
我想我找到我要找的书了
#10
pangding2012-08-20 22:37
也许楼主已经没兴趣了,不过既然老帖已经被翻出,来我也说两句。

这个编码设计其实是一个 Huffman 编码问题。逻辑其实是,所有的指令前缀都不是另一个指令。
假设一有一个指令是 ABACD,那么一定有这样的结论,即 A, AB, ABA, ABAC 都不是指令。所以解码的时候,只要往后读,直到 cpu 发现读过的部分已经是一个指令了,就可以立即去执行了。

这是理论模型,事实上真正实现一个合理的编码还要考虑很多优化问题。
1