前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CPU的核心原理

CPU的核心原理

作者头像
硬核编程
发布2019-08-19 21:35:32
4910
发布2019-08-19 21:35:32
举报

前面我们这里假设的 CPU 很基础,所有指令都是 8 位,操作码只占了前面 4 位,即便用尽 4 位,也只能代表 16 个指令,而且我们有几条指令,是用后 4 位来指定内存地址,因为 4 位最多只能表示 16 个值,所以我们只能操作 16 个地址,这可不多。我们甚至不能 JUMP 17,因为 4 位二进制无法表示数字 17。

真正的现代 CPU 用两种策略

  1. 最直接的方法是用更多位来代表指令,比如 32 位或 64 位,这叫 指令长度。
  2. 第二个策略是 "可变指令长度",举个例子,比如某个 CPU 用 8 位长度的操作码,如果看到 HALT 指令,HALT 不需要额外数据,那么会马上执行。如果看到 JUMP,它得知道位置值,这个值在 JUMP 的后面,这叫 "立即值"。这样设计,指令可以是任意长度,但会让读取阶段复杂一点点。

4004 处理器

要说明的是,我们拿来举例的 CPU 和指令集都是假设的,是为了展示核心原理所以我们来看个真的 CPU 例子。

1971年,英特尔发布了 4004 处理器。这是第一次把 CPU 做成一个芯片,给后来的英特尔处理器打下了基础,它支持 46 个指令,足够做一台能用的电脑。它用了很多我们说过的指令,比如 JUMP ADD SUB LOAD,它也用 8 位的"立即值"来执行 JUMP, 以表示更多内存地址。

处理器发展

处理器从 1971 年到现在发展巨大.,现代 CPU, 比如英特尔酷睿 i7, 有上千个指令和指令变种,长度从1到15个字节。举例,光 ADD 指令就有很多变种。指令越来越多,是因为给 CPU 设计了越来越多功能。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员成长充电站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档