上个世纪70年代,内存又慢又贵, 程序员得想尽一切办法节省内存。

那个时代的编译器也比较差劲

所以,70年代的程序员几乎都写得一手好汇编。

为了帮助程序员写好汇编,这个时候的CPU也有意把指令集做了增强。

80年代初,Intel 的x86 CPU和微软的DOS被IBM选中,成为了IBM PC兼容机的处理器和操作系统。

在摩尔定律的支配下, x86 CPU 变得越来越复杂。

最后,连编译器都受不了了。

IBM研究院的John Cocke发现,处理器提供的大量指令集和寻址方式并不会被编译器生成的代码用到。

既然如此,为什么不设计一个新的指令集,保留这最常用的20%的指令呢?

这样CPU的设计和实现岂不更加简单?

这就是著名的精简指令集(RISC)的思路。

当时,IBM,加州大学伯克利分校的David Patterson,斯坦福大学的John Hennessy是RISC研究的先驱。

RISC可不仅仅把指令做了精简,还有其他一些非常重要的提升。

新理论的诞生从来都不是一帆风顺的,当时CICS的一些设计大师就持不同意见。

David Patterson憋着一口气,带领自己的学生,设计出了一款RISC处理器, 1982年, RISC-I处理器发布了。

看到RISC有如此表现,一大批公司开始采用RISC的思路来设计处理器,RISC如同星火燎原之势,迅速攻占了服务器端市场。

虽然牢牢统治者PC市场,但RISC的发展让Intel 感受到了巨大的压力,Intel决定两条腿走路。

但是PC是x86架构,所有的操作系统和软件都围绕它来构建。

i860连兼容的操作系统和软件都没有,根本就发展不下去。

既然RISC发展不起来,Intel 下定决心,抛弃RISC, 一条道走到黑。

到了1995年,Intel终于找到了办法,那就是把x86的指令集,解码成类似于RISC的微操作(uops),执行的时候采用RISC内核。

Intel利用从PC市场赚取的巨额利润,不断投入,随着体系结构和微电子技术的进步,CICS在结构上的劣势逐渐消失。

在Intel 的进攻下, RISC在服务器CPU市场节节败退,时至今日,被Intel占据了95%的市场。

再加上桌面市场, x86几乎完成了垄断。

RISC就此失败了吗?

在90年代和21世纪初,PC占据了主导地位,但是一颗新星正在蛰伏,等待爆发。

但是很遗憾,Newton技术过于超前,用户体验糟糕,未被市场接受,以失败告终。

但ARM积累了经验,继续改进技术。没过多久,便在诺基亚等功能机上获得了成功。

2007年, ARM终于迎来了自己的黄金时代。

后面的故事大家都比较清楚了, ARM 踏上了移动时代的浪潮,统治了手机市场。

不仅如此,统治了移动市场的ARM,开始反攻服务器和台式机了!

2007年,David Patterson和John Hennessy由于在RISC领域的卓越贡献获得图灵奖

实际上,回顾CPU过去40年的发展,Intel曾经向RISC学习,搞出了RISC内核。

而ARM也引入了代码密度更高的新指令集,向CISC取经。

CISC与RISC在指令集架构层面上的差异已经被弥合。

漫画 | CPU战争40年,真正的王者终于现身!的更多相关文章

  1. [No000038]操作系统Operating Systems -CPU

    管理CPU ,先要使用CPU… CPU 的工作原理 CPU上电以后发生了什么? 自动的取指 — 执行 CPU 怎么工作? CPU怎么管理? 管理CPU 的最直观方法 设好PC 初值就完事! 看看这样做 ...

  2. 如何限制虚拟主机可使用的CPU资源

    使用IIS 6.0运营虚拟主机的朋友们都会碰到这样一个问题,当某个网站占用大量CPU资源时,会把整个服务器都拖慢了,影响服务器上其他网站的访问速度,客户们的投诉也让系统管理员倍感头疼.我们知道,从II ...

  3. TRUNCATE引起CPU异常上涨

    13:05 2015/9/11 午睡醒来收到几封CPU使用率预警邮件.登录对应服务器,打开资源监视器,看到sqlservr.exe进程的CPU达到40%(平常服务器CPU消耗在10%以内).查看CPU ...

  4. SQL 数据库高CPU占用语句排查

    前述 最近一个项目CPU占用非常高,在IIS内设置CPU限制后系统频繁掉线,通过任务管理器发现SQLSever数据库占用CPU达到40%--70%,对于数据库本人也就处在增删查改几个操作水平层面,这次 ...

  5. Linux查看CPU和内存的配置信息

    CPU配置信息:frank@ubuntu:~/test/python$ cat /proc/cpuinfo processor : #系统中逻辑处理核的编号 vendor_id : GenuineIn ...

  6. Intel CPU Microarchitecture

    http://en.wikipedia.org/wiki/Intel_Tick_Tock Atom Roadmap[16]   Fabrication process Microarchitectur ...

  7. CPU 执行程序的秘密,藏在了这 15 张图里

    前言 代码写了那么多,你知道 a = 1 + 2 这条代码是怎么被 CPU 执行的吗? 软件用了那么多,你知道软件的 32 位和 64 位之间的区别吗?再来 32 位的操作系统可以运行在 64 位的电 ...

  8. SQL SERVER数据库服务器CPU不能全部利用原因分析

    背景 客户凌晨把HIS数据库迁移到配置更高的新服务器,上午业务高峰时应用非常缓慢,严重影响到业务运行.   1.现象 通过SQL专家云实时可视化界面看到大量的绿点,绿点表示会话在等待某项资源,绿点越大 ...

  9. 《自己动手写CPU》写书评获赠书活动结果

    <自己动手写CPU>写书评获赠图书的读者有: 京东:8***2.16号哨兵.magicyu.kk6803.jddickyd.杰出的胡兵 亚马逊:徐贺.马先童.jaychen.farmfar ...

随机推荐

  1. Netty学习之IO模型

    目录 1.1 同步.异步.阻塞.非阻塞     同步 VS 异步         同步         异步     阻塞 VS 非阻塞         阻塞         非阻塞     举例   ...

  2. python 3.6 导入c++dll所遇到的坑

    1 返回值在c++里面为const char*,python 接收实际上为int类型 原因:python默认返回值为int 解决方法: import ctypes import os CUR_PATH ...

  3. Itranswarp 搭建个人 Wiki

    www.swack.cn - 原文链接:Itranswarp 搭建个人 Wiki 从零开始 搭建个人Wiki站点 Itranswarp.js 是一款基于nodejs开发的博客系统,通过Apache L ...

  4. 【剑指 Offer】12.矩阵中的路径

    题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左.右.上.下移动一格. 如果一条路径经过了矩阵的某一格,那么 ...

  5. Flutter 基础组件:单选框和复选框

    前言 Material组件库中提供了Material风格的单选开关Switch和复选框Checkbox,虽然它们都是继承自StatefulWidget,但它们本身不会保存当前选中状态,选中状态都是由父 ...

  6. 九:APP及其他资产

    APP提取一键反编译提取 APP抓数据包进行工具配合 各种第三方应用相关探针技术 各种服务器接口相关探针技术 APP提取及抓包及后续配合 某APK一键提取反编译 利用burp历史抓更多URL 某IP无 ...

  7. Linux Clone函数

    Linux Clone函数 之前某一次有过一次面试,问了内核中是怎么创建命名空间的? 下面就来扒一扒clone的精髓,以及如何通过它创建命名空间. 目录 Linux Clone函数 使用clone创建 ...

  8. 【Git】4、创建代码仓库,HTTP、SSH拉取远端代码

    拉取远端代码:使用Git命令下载远程仓库到本地 文章目录 拉取远端代码:使用Git命令下载远程仓库到本地 1.创建远程代码仓库 2.创建仓库 3.进入仓库 4.HTTP(S)获取远程仓库 首次拉取 更 ...

  9. 电子邮箱、邮件地址、网站地址正则表达式!几个有用的RE、regex、regexp!

    几个常用的正则表达式! r"\w[-\w\.]*@\w[-\w]*(\.\w[-\w]*)+" 这个是电子邮件地址的. r"<TAG\b[^>]*<(. ...

  10. kubernets之存活探针

    一   存活探针存在的意义 1.1  kubernet通过存活探针(liveness probe)检查容器是否还在运行,可以为pod中的每个容器单独指定存活探针,如果探针执行失败,kubernets会 ...