0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

寄存器比内存快的原理是什么?

Linux阅码场 来源:未知 作者:胡薇 2018-08-02 16:17 次阅读

计算机的存储层次(memory hierarchy)之中,寄存器(register)最快,内存其次,最慢的是硬盘。

同样都是晶体管存储设备,为什么寄存器比内存快呢?

Mike Ash写了一篇很好的解释,非常通俗地回答了这个问题,有助于加深对硬件的理解。下面就是我的简单翻译。

原因一:距离不同

距离不是主要因素,但是最好懂,所以放在最前面说。内存离CPU比较远,所以要耗费更长的时间读取。

以3GHz的CPU为例,电流每秒钟可以振荡30亿次,每次耗时大约为0.33纳秒。光在1纳秒的时间内,可以前进30厘米。也就是说,在CPU的一个时钟周期内(0.33纳秒),光可以前进10厘米。

涛声依旧注:每次震荡的耗时也就是CPU的时钟周期,时钟周期为震荡频率的倒数。

因此,如果内存距离CPU超过5厘米,就不可能在一个时钟周期内完成数据的读取,这还没有考虑硬件的限制和电流实际上达不到光速。相比之下,寄存器在CPU内部,当然读起来会快一点。

距离对于桌面电脑影响很大,对于手机影响就要小得多。手机CPU的时钟频率比较慢(iPhone 5s为1.3GHz),而且手机的内存紧挨着CPU。

原因二:硬件设计不同

苹果公司新推出的iPhone 5s,CPU是A7,寄存器有6000多位(31个64位寄存器,加上32个128位寄存器)。而iPhone 5s的内存是1GB,约为80亿位(bit)。

这意味着,高性能、高成本、高耗电的设计可以用在寄存器上,反正只有6000多位,而不能用在内存上。因为每个位的成本和能耗只要增加一点点,就会被放大80亿倍。

事实上确实如此,内存的设计相对简单,每个位就是一个电容和一个晶体管,而寄存器的设计则完全不同,多出好几个电子元件。

并且通电以后,寄存器的晶体管一直有电,而内存的晶体管只有用到的才有电,没用到的就没电,这样有利于省电。

这些设计上的因素,决定了寄存器比内存读取速度更快。

原因三:工作方式不同

寄存器的工作方式很简单,只有两步:

(1)找到相关的位

(2)读取这些位。

内存的工作方式就要复杂得多:

1.找到数据的指针。(指针可能存放在寄存器内,所以这一步就已经包括寄存器的全部工作了。)

2. 将指针送往内存管理单元(MMU),由MMU将虚拟的内存地址翻译成实际的物理地址。

3. 将物理地址送往内存控制器(memory controller),由内存控制器找出该地址在哪一根内存插槽(bank)上。

4.确定数据在哪一个内存块(chunk)上,从该块读取数据。

5. 数据先送回内存控制器,再送回CPU,然后开始使用。

内存的工作流程比寄存器多出许多步。每一步都会产生延迟,累积起来就使得内存比寄存器慢得多。

为了缓解寄存器与内存之间的巨大速度差异,硬件设计师做出了许多努力,包括在CPU内部设置缓存、优化CPU工作方式,尽量一次性从内存读取指令所要用到的全部数据等等。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5377

    浏览量

    121394
  • 内存
    +关注

    关注

    8

    文章

    3071

    浏览量

    74414

原文标题:为什么寄存器比内存快?

文章出处:【微信号:LinuxDev,微信公众号:Linux阅码场】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    为什么寄存器的速度内存

    `在看C专家编程的时候, 上面有一幅图,整理的是内存媒介的速度,与成本的关系说明, 这里我在网上找了一张说明更为细致的图:那为什么寄存器的速度会比内存?Mike Ash写了一篇很好的
    发表于 12-27 10:19

    闪存存储寄存器吗?_寄存器和存储的区别

    寄存器)、成本高,它用名字来标识(如AX、BX等),没有地址;;存储在CPU的外部,它的访问速度寄存器慢,容量大(20根地址线寻址1M内存
    发表于 10-11 17:12 1.2w次阅读

    寄存器Load/Store内存访问指令

    5.4 多寄存器Load/Store内存访问指令 多寄存器Load/Store内存访问指令也叫批量加载/存储指令,它可以实现在一组寄存器和一
    发表于 10-18 15:56 1次下载

    为什么寄存器内存_原因是这个

    本文开始介绍了寄存器特点、分类以及寄存器的工作原理,其次介绍了内存的容量、大小与选购方法,最后阐述了寄存器
    发表于 04-11 09:09 7169次阅读
    为什么<b class='flag-5'>寄存器</b><b class='flag-5'>比</b><b class='flag-5'>内存</b><b class='flag-5'>快</b>_原因是这个

    逆向基础之寄存器内存详解

    本文主要介绍的是逆向基础的寄存器内存方面的信息,首先介绍的是逆向主要是做什么的,其次对编程和机器架构做了个简介,最后详细的阐述了逆向基础的寄存器内存
    发表于 04-26 09:52 3039次阅读

    RFM反射内存5565控制和状态寄存器

    3.3 RFM反射内存控制和状态寄存器 内存访问周期RFM5565 反射内存控制和状态寄存器,偏移值存储在基址
    发表于 08-13 07:58 1395次阅读

    寄存器变量

    C语言中使用关键字register来声明局部变量为寄存器变量。寄存器变量的值会被存放在CPU的寄存器中,每当需要使用它们时,CPU就可以直接使用,而无须再通过控制
    发表于 06-03 10:13 2429次阅读

    寄存器变量定义

     寄存器变量和普通变量比起来速度上的差异很大,毕竟CPU的速度远远大于内存的速度。寄存器有这么两个特点,一个是运算速度,一个是不能取地址。
    发表于 06-03 10:40 4102次阅读

    计算机中内存、cache和寄存器之间的关系

    CPU、内存寄存器之间的关系cpu 取址 -》地址输入地址寄存器 -》 缓存命中即,则数据进入数据寄存器 -》 缓存未命中则进入内存 -》
    发表于 07-22 09:19 5807次阅读
    计算机中<b class='flag-5'>内存</b>、cache和<b class='flag-5'>寄存器</b>之间的关系

    寄存器内存的区别

    寄存器是中央处理内的组成部份。它跟CPU有关。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。在中央处理的控制部件中,包含的
    发表于 12-31 16:57 1w次阅读

    CS,IP和PC寄存器

    CS寄存器和IP寄存器:首先强调一下,这两个寄存器非常非常重要,CS的全拼为“Code segment”,即代码段寄存器,对应于内存中的存放
    发表于 12-17 18:31 2次下载
    CS,IP和PC<b class='flag-5'>寄存器</b>

    CPU、寄存器内存单元的物理结构

    这个问题应该从cpu、寄存器内存单元的物理结构来看。
    的头像 发表于 09-05 11:17 4441次阅读

    访问CXL 2.0设备中的内存映射寄存器

    计算快速链接 (CXL) 1.1 和 CXL 2.0 规范在内存映射寄存器的放置和访问方式上有所不同。CXL 1.1 规范将内存映射寄存器放置在 RCRB(根复合
    的头像 发表于 05-25 16:56 2187次阅读
    访问CXL 2.0设备中的<b class='flag-5'>内存</b>映射<b class='flag-5'>寄存器</b>

    寄存器内存的区别

    在计算机体系结构中,寄存器内存是两个至关重要的组成部分。它们各自承担着不同的角色,共同确保计算机系统的正常运行。本文将对寄存器内存进行详细的介绍,包括它们的定义、功能以及二者之间的
    的头像 发表于 05-12 17:11 2686次阅读

    寄存器分为基本寄存器和什么两种

    ,它们用于存储指令、数据和地址等信息。基本寄存器的容量通常较小,但访问速度非常,因为它们与CPU的执行单元紧密相连。 基本寄存器的分类 基本寄存器可以分为以下几类: (1)通用
    的头像 发表于 07-12 10:31 1657次阅读