| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 801 人关注过本帖
标题:cpu怎么知道一次应该从内存里面取几个字节?
只看楼主 加入收藏
wobianlong
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2012-8-1
结帖率:92.86%
收藏
已结贴  问题点数:20 回复次数:9 
cpu怎么知道一次应该从内存里面取几个字节?
有些指令占据内存是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*****类似的指令出现,这样对吗?
还请大家指导啊
搜索更多相关主题的帖子: 如何 
2012-08-06 16:31
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:10 
CPU里面有个解码器 把指令解码然后做相应的东西

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

对啊 这就是解码器的工作

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

指令的构造有一定的规则 在定的时候已经考虑这个了罢 不大可能会出现这个问题 具体情况请看intel的指令手册
2012-08-06 16:36
wobianlong
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2012-8-1
收藏
得分:0 
明白了,请问这个问题你是怎么知道的啊,看的什么书啊

我听到有人问为什么,就用光一样的速度从大爆炸时代赶来了,遍布于世界各地的危险
2012-08-06 16:48
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:0 
其实最权威的是intel的手册 看那个比看神马书都好 我就是看过指令手册 其他都没看过
2012-08-06 17:10
wobianlong
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2012-8-1
收藏
得分:0 
以下是引用zklhp在2012-8-6 17:10:30的发言:

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

看手册什么的感觉很枯燥,真看不懂啊,看不进去

我听到有人问为什么,就用光一样的速度从大爆炸时代赶来了,遍布于世界各地的危险
2012-08-06 17:49
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:0 
对啊 又不是全看 找你感兴趣的看看呗 比如 指令的构成规则 也就是你感兴趣的

图片附件: 游客没有浏览图片的权限,请 登录注册

看着一块 你自然知道指令大概怎么构成的了 也就能解答你的疑惑了
2012-08-06 18:07
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:0 
如果你想知道更底层的 硬件实现 那你应该看有关CPU设计 实现原理 等的书 不过这种书我没看懂 呵呵 也不好说了

祝好运

没问题记得结题
2012-08-06 18:09
bingghost
Rank: 2
等 级:论坛游民
帖 子:70
专家分:85
注 册:2012-1-4
收藏
得分:10 
Opcode    Opcode

我的头像就是我的女神 可惜我的女神已经死了 所以我的心也死了
2012-08-07 12:11
洪荒一鼎
Rank: 2
等 级:论坛游民
帖 子:34
专家分:46
注 册:2012-6-27
收藏
得分:0 
我想我找到我要找的书了

不知道,不懂,知道,了解,懂,精通
2012-08-20 09:30
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
收藏
得分:0 
也许楼主已经没兴趣了,不过既然老帖已经被翻出,来我也说两句。

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

这是理论模型,事实上真正实现一个合理的编码还要考虑很多优化问题。
2012-08-20 22:37
快速回复:cpu怎么知道一次应该从内存里面取几个字节?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016816 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved