范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

CPU的基本知识总结

  一、关于CPU和程序的执行
  CPU是计算机的大脑。
  1、程序的运行过程,实际上是程序涉及到的、未涉及到的一大堆的指令的执行过程。
  当程序要执行的部分被装载到内存后,CPU要从内存中取出指令,然后指令解码(以便知道类型和操作数,简单的理解为CPU要知道这是什么指令),然后执行该指令。再然后取下一个指令、解码、执行,以此类推直到程序退出。
  2、这个取指、解码、执行三个过程构成一个CPU的基本周期。
  3、每个CPU都有一套自己可以执行的专门的指令集(注意,这部分指令是CPU提供的,CPU-Z软件可查看)。
  正是因为不同CPU架构的指令集不同,使得x86处理器不能执行ARM程序,ARM程序也不能执行x86程序。(Intel和AMD都使用x86指令集,手机绝大多数使用ARM指令集)。
  注:指令集的软硬件层次之分:硬件指令集是硬件层次上由CPU自身提供的可执行的指令集合。软件指令集是指语言程序库所提供的指令,只要安装了该语言的程序库,指令就可以执行。
  4、由于CPU访问内存以得到指令或数据的时间要比执行指令花费的时间长很多,因此在CPU内部提供了一些用来保存关键变量、临时数据等信息的通用寄存器。
  所以,CPU需要提供 一些特定的指令,使得可以从内存中读取数据存入寄存器以及可以将寄存器数据存入内存。此外还需要提供加法、减、not/and/or等基本运算指令,而乘除法运算都是推算出来的(支持的基本运算指令参见ALU Functions),所以乘除法的速度要慢的多。这也是算法里在考虑时间复杂度时常常忽略加减法次数带来的影响,而考虑乘除法的次数的原因。
  5、除了通用寄存器,还有一些特殊的寄存器。典型的如:PC:program counter,表示程序计数器,它保存了将要取出的下一条指令的内存地址,指令取出后,就会更新该寄存器指向下一条指令。堆栈指针:指向内存当前栈的顶端,包含了每个函数执行过程的栈帧,该栈帧中保存了该函数相关的输入参数、局部变量、以及一些没有保存在寄存器中的临时变量。PSW:program status word,表示程序状态字,这个寄存器内保存了一些控制位,比如CPU的优先级、CPU的工作模式(用户态还是内核态模式)等。
  6、在CPU进行进程切换的时候,需要将寄存器中和当前进程有关的状态数据写入内存对应的位置(内核中该进程的栈空间)保存起来,当切换回该进程时,需要从内存中拷贝回寄存器中。即上下文切换时,需要保护现场和恢复现场。
  7、为了改善性能,CPU已经不是单条取指-->解码-->执行的路线,而是分别为这3个过程分别提供独立的取值单元,解码单元以及执行单元。这样就形成了流水线模式。
  例如,流水线的最后一个单元——执行单元正在执行第n条指令,而前一个单元可以对第n+1条指令进行解码,再前一个单元即取指单元可以去读取第n+2条指令。这是三阶段的流水线,还可能会有更长的流水线模式。
  8、更优化的CPU架构是superscalar架构(超标量架构)。这种架构将取指、解码、执行单元分开,有大量的执行单元,然后每个取指+解码的部分都以并行的方式运行。比如有2个取指+解码的并行工作线路,每个工作线路都将解码后的指令放入一个缓存缓冲区等待执行单元去取出执行。
  9、除了嵌入式系统,多数CPU都有两种工作模式:内核态和用户态。这两种工作模式是由PSW寄存器上的一个二进制位来控制的。
  10、内核态的CPU,可以执行指令集中的所有指令,并使用硬件的所有功能。
  11、用户态的CPU,只允许执行指令集中的部分指令。一般而言,IO相关和把内存保护相关的所有执行在用户态下都是被禁止的,此外其它一些特权指令也是被禁止的,比如用户态下不能将PSW的模式设置控制位设置成内核态。
  12、用户态CPU想要执行特权操作,需要发起系统调用来请求内核帮忙完成对应的操作。其实是在发起系统调用后,CPU会执行trap指令陷入(trap)到内核。当特权操作完成后,需要执行一个指令让CPU返回到用户态。
  13、除了系统调用会陷入内核,更多的是硬件会引起trap行为陷入内核,使得CPU控制权可以回到操作系统,以便操作系统去决定如何处理硬件异常。
  二、关于CPU的基本组成
  1、CPU是用来运算的(加法运算+、乘法运算*、逻辑运算and not or等),例如c=a+b。
  2、运算操作涉及到数据输入(input)、处理、数据输出(output),a和b是输入数据,加法运算是处理,c是输出数据。
  3、CPU需要使用一个叫做存储器(也就是各种寄存器)的东西保存输入和输出数据。以下是几种常见的寄存器(前文也介绍了一些)MAR: memory address register,保存将要被访问数据在内存中哪个地址处,保存的是地址值MDR: memory data register,保存从内存读取进来的数据或将要写入内存的数据,保存的是数据值AC: Accumulator,保存算术运算和逻辑运算的中间结果,保存的是数据值PC: Program Counter,保存下一个将要被执行指令的地址,保存的是地址值CIR: current instruction register,保存当前正在执行的指令
  4、CPU还要将一些常用的基本运算工具(如加法器)放进CPU,这部分负责运算,称为算术逻辑单元(ALU, Arithmetic Logic Unit)。
  5、CPU中还有一个控制器(CU, Control Unit),负责将存储器中的数据送到ALU中去做运算,并将运算后的结果存回到存储器中。控制器还包含了一些控制信号。
  5、控制器之所以知道数据放哪里、做什么运算(比如是做加法还是逻辑运算?)都是由指令告诉控制器的,每个指令对应一个基本操作,比如加法运算对应一个指令。
  6、例如,将两个MDR寄存器(保存了来自内存的两个数据)中的值拷贝到ALU中,然后根据指定的操作指令执行加法运算,将运算结果拷贝会一个MDR寄存器中,最后写入到内存。
  7、这就是冯诺依曼结构图,也就是现在计算机的结构图。
  三、关于CPU的多核和多线程
  1、CPU的物理个数由主板上的插槽数量决定,每个CPU可以有多核心,每核心可能会有多线程。
  2、多核CPU的每核(每核都是一个小芯片),在OS看来都是一个独立的CPU。
  3、对于超线程CPU来说,每核CPU可以有多个线程(数量是两个,比如1核双线程,2核4线程,4核8线程),每个线程都是一个虚拟的逻辑CPU(比如windows下是以逻辑处理器的名称称呼的),而每个线程在OS看来也是独立的CPU。
  这是欺骗操作系统的行为,在物理上仍然只有1核,只不过在超线程CPU的角度上看,它认为它的超线程会加速程序的运行。
  4、要发挥超线程优势,需要操作系统对超线程有专门的优化。
  5、多线程的CPU在能力上,比非多线程的CPU核心要更强,但每个线程不足以与独立的CPU核心能力相比较。
  6、每核上的多线程CPU都共享该核的CPU资源。
  例如,假设每核CPU都只有一个"发动机"资源,那么线程1这个虚拟CPU使用了这个"发动机"后,线程2就没法使用,只能等待。
  所以,超线程技术的主要目的是为了增加流水线(参见前文对流水线的解释)上更多个独立的指令,这样线程1和线程2在流水线上就尽量不会争抢该核CPU资源。所以,超线程技术利用了superscalar(超标量)架构的优点。
  7、多线程意味着每核可以有多个线程的状态。比如某核的线程1空闲,线程2运行。
  8、多线程没有提供真正意义上的并行处理,每核CPU在某一时刻仍然只能运行一个进程,因为线程1和线程2是共享某核CPU资源的。可以简单的认为每核CPU在独立执行进程的能力上,有一个资源是唯一的,线程1获取了该资源,线程2就没法获取。
  但是,线程1和线程2在很多方面上是可以并行执行的。比如可以并行取指、并行解码、并行执行指令等。所以虽然单核在同一时间只能执行一个进程,但线程1和线程2可以互相帮助,加速进程的执行。
  并且,如果线程1在某一时刻获取了该核执行进程的能力,假设此刻该进程发出了IO请求,于是线程1掌握的执行进程的能力,就可以被线程2获取,即切换到线程2。这是在执行线程间的切换,是非常轻量级的。(WIKI: if resources for one process are not available, then another process can continue if its resources are available)
  9、多线程可能会出现一种现象:假如2核4线程CPU,有两个进程要被调度,那么只有两个线程会处于运行状态,如果这两个线程是在同一核上,则另一核完全空转,处于浪费状态。更期望的结果是每核上都有一个CPU分别调度这两个进程。
  四、关于CPU上的高速缓存
  1、最高速的缓存是CPU的寄存器,它们和CPU的材料相同,最靠近CPU或最接近CPU,访问它们没有时延(<1ns)。但容量很小,小于1kb。32bit:32*32比特=128字节64bit:64*64比特=512字节
  2、寄存器之下,是CPU的高速缓存。分为L1缓存、L2缓存、L3缓存,每层速度按数量级递减、容量也越来越大。
  3、每核心都有一个自己的L1缓存。L1缓存分两种:L1指令缓存(L1-icache)和L1数据缓存(L1-dcache)。L1指令缓存用来存放已解码指令,L1数据缓存用来放访问非常频繁的数据。
  4、L2缓存用来存放近期使用过的内存数据。更严格地说,存放的是很可能将来会被CPU使用的数据。
  5、多数多核CPU的各核都各自拥有一个L2缓存,但也有多核共享L2缓存的设计。无论如何,L1是各核私有的(但对某核内的多线程是共享的)。

一块电池加个苹果的logo就卖七百多块,别怀疑这妥妥的就是智商税看到标题大家应该就知道我说的是什么产品了吧?就是苹果之前发布的适用于iPhone12系列的MagSafe外接电池,售价749。要说苹果的官方配件卖得贵一些也无可厚非,毕竟人家一个数使用苹果手机就不算爱国吗?最近美国联合日本以及欧洲国家频繁制裁中国。很多人都认为应该抵制美货日货,支持国货。那么使用苹果手机,购买日系车的中国人真的就不爱国吗?支持国货就是爱国吗?不可否认苹果手机很流畅反应哪个牌子的投影仪性价比高?烧友分享3000元投影仪品牌推荐因为功能丰富多样,智能投影仪受到了市场的认可,很多朋友在挑选投影仪的时候除了基本的分辨率配置亮度等因素外,还会考虑到性价比,关于哪个牌子的投影仪性价比高,发烧友峰子今天就来解答一下联发科发布天玑920810,6nm工艺加持,realme拿下首发权处理器作为手机的核心,在很大程度上决定了手机的性能,这也导致了消费者群体中出现了唯处理器论。目前主流的手机处理器阵营基本上也属于泾渭分明,先是苹果的A系列一骑绝尘,随后高通骁龙海思iPhone13最终曝光9月发布价格依然5499,国产手机如临大敌这段时间国产手机发布新机可谓是非常活跃,除了好不容易等来的华为P50系列,小米MIX4,荣耀Magic3等重磅新机也都一并发布。而接下来在路上的还有至少34款新机。并且不知道大家发程序员8月薪资新鲜出炉,圈外人却在酸?北京在本次榜单中依旧是占据首位,下面先看下完整的8月薪资排行榜榜单中南京已经连续半年薪资在广州之上了,在2018年的时候广州总是和深圳放在一起对比。但是最近南京和广州也总是被热议,1450,魅族17梦幻独角兽,yyds近段时间准备换手机,当然首先考虑的是2手机,入了2手的坑后就再也没有买过新机了,经过慎重考虑(没有钱啊,肯定要考虑啊,有钱还考虑个鬼)然后我选定了搭载865处理器性价比最高的3款手7月手机性价比排行榜单出炉Redmi成最大赢家,欧加系表现亮眼8月13日,安兔兔发布了一份2021年7月份各价位手机性价比排行榜单,这份榜单是基于京东目前的在售机型进行整理的,大家可以来参考一下。毕竟马上就要到818电商大促销了,届时又是一波支付宝客服回应宕机七夕13。14红包功能太过火爆IT之家8月14日消息今日是农历七月初七,是中国最具浪漫色彩的传统节日七夕节。不少网友在今天纷纷表示自己的支付宝崩了,该话题很快引起大量关注登上热搜。目前支付宝系统已经恢复正常。今常用数组方法看过的有福了找元素arr。indexOf()找到返回索引,找不到返回1arr。includes(item,2)从索引为2开始找,返回true或者false可以用于去重增删改查arr。push(修复众多BUG?小米10S升级MIUI12。5增强版体验于昨晚9点56分开始收到MIUI12。5增强版的更新包,内心还是有点小激动,此次更新主打修复和优化,更新包大小为274M满满一页的bug,可见这次稳定版存在许多问题,也证明了工程师
最漂亮的水中倒影照片,你敢发出来让大家欣赏吗?漂亮的水中倒影照片,人人看了都喜欢,我也喜欢水中的倒影,凡是看到好的水中到影风景,我都喜欢用手机即刻拍下来珍藏起来,自己慢慢的欣赏美丽的水中倒影风景。下面是本人在上海的世纪公园川杨关于Python的Selenium框架全解,一篇完整的说明书目录selenium基础语法一环境配置1安装环境安装selenium第三方库pipinstallselenium下载浏览器驱动Firefox浏览器驱动geckodriverChro3月1日微信支付宝收款都有哪些新规?你知道多少?微信支付宝3月1日新规定,具体发布的新规定是什么?主要有三点1个人收款代码远程收款功能有限。2商家不能用微信支付宝的个人收据收款。3。收款代码分为个人和特约商人两大类,实行分类管理加密货币使得俄罗斯更容易规避制裁近日,据美国媒体报道,一些区块链专家表示,西方对俄罗斯实施的金融制裁措施变得越来越容易被规避,部分原因是俄罗斯正大量采用加密货币。据美国有线电视新闻网(CNN)2月24日报道,随着Java集合类框架详解Java集合框架概述集合可以看作是一种容器,用来存储对象信息。所有集合类都位于java。util包下,但支持多线程的集合类位于java。util。concurrent包下。Java中国智能终端产品行业深度研究与产业竞争格局中国产业研究报告网发布的20222028年中国智能终端产品行业深度研究与产业竞争格局报告共十一章。首先介绍了智能终端产品行业市场发展环境智能终端产品整体运行态势等,接着分析了智能终微信新更新的版本,哪些小程序好用?自从12月微信更新了新版本,从聊天窗口拉下就能找到已关注的小程序。新上线了微信跳一跳小程序游戏,可以说小程序一下子火了起来。我们都会有这样的问题,还有什么好用或者好玩的小程序吗?答关于元宇宙的现实应用猜想其实我一直有自不量力的想给华为总部写信的冲动,想谈一谈关于元宇宙的现实应用,其实元宇宙这项技术确实很先进,但再先进的技术也应该归于现实的应用,我非常建议华为将元宇宙技术用于现在的华国产电视销售第一名,打败日本索尼成全球第三,海信也不是对手随着时代的发展,人们的日常生活中出现了许多新奇的产品,在没有通电的年代,人们就只能通过看皮影戏来解乏。随着有电时代的到来,人们的生活更是发生了翻天覆地的变化,先是出现了电视机,后出微型电动机可产生335马力。仅重28。58公斤这款名为Quark的发动机仅重28。58公斤,声称拥有业内最佳的扭矩重量比。瑞典超级跑车制造商科尼赛克长期以来一直是创新技术的发源地,它在其新型电动机中得到了体现。这款名为Quar霍老师谈CRM我独的家提出一关个于私域概的念私域,是就微信CRM。CRM是什么?CRM就是客户关系理管。也就是说,私,域就是我们用信微来管理自己的客户包,括引流包,括运营,包复括购,包括变裂。第