当前位置: 首页 > news >正文

寄存器、缓存、内存之间的关系和区别

https://blog.csdn.net/m0_46761060/article/details/124689209

目录
  • 关系
  • 1、寄存器
  • 2、缓存(Cache)
    • 2.1、寄存器和缓存的区别
    • 2.2、一级缓存和二级缓存
  • 3、内存
    • 3.1、只读存储器 ROM(Read Only Memory)
    • 3.2、随机存储器 RAM(Random Access Memory)
      • 3.2.1、静态RAM(Static RAM/SRAM)
      • 3.2.2、动态RAM(Dynamic RAM/DRAM)

关系

在这里插入图片描述

1、寄存器

寄存器(register)是CPU(中央处理器)的组成部分,是一种直接整合到cpu中的有限的高速访问速度的存储器,它是有一些与非门组合组成的,分为通用寄存器和特殊寄存器。cpu访问寄存器的速度是最快的。那为什么我们不把数据都存储到寄存器中呢,因为寄存器是一种容量有限的存储器,并且非常小。因此只把一些计算机的指令等一些计算机频繁用到的数据存储在其中,来提高计算机的运行速度。

2、缓存(Cache)

缓存就是数据交换的缓冲区(称作Cache),当某一硬件要读取数据时,会首先从缓存中查找需要的数据,如果找到了则直接执行,找不到的话则从内存中找。由于缓存的运行速度比内存快得多,故缓存的作用就是帮助硬件更快地运行。

因为缓存往往使用的是RAM(断电即掉的非永久储存),所以在用完后还是会把文件送到硬盘等存储器里永久存储。电脑里最大的缓存就是内存条了,最快的是CPU上镶的L1和L2缓存,显卡的显存是给显卡运算芯片用的缓存,硬盘上也有16M或者32M的缓存。

CACHE是在CPU中速度非常块,而容量却很小的一种存储器,它是计算机存储器中最强悍的存储器。由于技术限制,容量很难提升。

对于大多数人来说Cache,是透明的、不存在的。其中一个原因是Cache是集成到CPU中,对于程序员来说是透明的。

2.1、寄存器和缓存的区别

按与CPU远近来分,离得最近的是寄存器,然后缓存,最后内存。所以,寄存器是最贴近CPU的,而且CPU只与寄存器中进行存取。寄存器从内存中读取数据,但由于寄存器和内存读取速度相差太大,所以有了缓存。即读取数据的方式为:

CPU <------>寄存器 <---->缓存<----->内存

当寄存器没有从缓存中读取到数据时,也就是没有命中,那么就从内存中读取数据。

2.2、一级缓存和二级缓存

CPU读取数据的顺序为先缓存后内存。

CPU内部集成的缓存称为一级缓存(L1 Cache),外部的称为二级缓存(L2 Cache)。

一级缓存中又分为数据缓存(D-Cache)和指令缓存(I-Cache)。二者可以同时被CPU进行访问,减少了争用Cache所造成的冲突,提高了CPU的效能。

CPU的一级缓存通常都是静态RAM(Static RAM/SRAM),速度非常快,但是贵。

为提高系统的性能和速度又必须扩大缓存,所以在不扩大原来的静态RAM缓存容量的情况下,仅仅增加一些高速动态RAM(Dynamic RAM/DRAM)做为L2级缓存。高速动态RAM速度要比常规动态RAM快,但比原来的静态RAM缓存慢,而且成本也较为适中。一级缓存和二级缓存中的内容都是内存中访问频率高的数据的复制品(映射),它们的存在都是为了减少高速CPU对慢速内存的访问。

二级缓存是CPU性能表现的关键之一,在CPU核心不变化的情况下,增加二级缓存容量能使性能大幅度提高。而同一核心的CPU高低端之分往往也是在二级缓存上存在差异.

CPU在缓存中找到有用的数据被称为命中,当缓存中没有CPU所需的数据时(这时称为未命中),CPU才访问内存。从理论上讲,在一颗拥有二级缓存的CPU中,读取一级缓存的命中率为80%。也就是说CPU一级缓存中找到的有用数据占数据总量的80%,剩下的20%从二级缓存中读取。由于不能准确预测将要执行的数据,读取二级缓存的命中率也在80%左右(从二级缓存读到有用的数据占总数据的16%)。那么还有的数据就不得不从内存调用,但这已经是一个相当小的比例了。

在较高端CPU中,还会带有三级缓存,它是为读取二级缓存后未命中的数据设计的一种缓存,在拥有三级缓存的CPU中,只有约5%的数据需要从内存中调用,这进一步提高了CPU的效率,从某种意义上说,预取效率的提高,大大降低了生产成本却提供了非常接近理想状态的性能。

3、内存

ROM在系统停止供电的时候仍然可以保持数据,而RAM通常都是在掉电之后就丢失数据,典型的RAM就是计算机的内存。

3.1、只读存储器 ROM(Read Only Memory)

PROM是可编程的ROM,PROM和EPROM(可擦除可编程ROM)两者区别是,PROM是一次性的,也就是软件灌入后,就无法修改了,现在已经不可能使用了,而EPROM是通过紫外光的照射擦除原先的程序,是一种通用的存储器。另外一种EEPROM是通过电子擦除,价格很高,写入时间很长,写入很慢。

3.2、随机存储器 RAM(Random Access Memory)

3.2.1、静态RAM(Static RAM/SRAM)

当数据被存入其中后不会消失。SRAM速度非常快,是目前读写最快的存储设备。当这个SRAM 单元被赋予0 或者1 的状态之后,它会保持这个状态直到下次被赋予新的状态或者断电之后才会更改或者消失。需要4-6 只晶体管实现, 价格昂贵。

3.2.2、动态RAM(Dynamic RAM/DRAM)

DRAM 必须在一定的时间内不停的刷新才能保持其中存储的数据。DRAM 只要1 只晶体管就可以实现。

DRAM保留数据的时间很短,速度也比SRAM慢,不过它还是比任何的ROM都要快,但从价格上来说DRAM相比SRAM要便宜很 多,计算机内存就是DRAM的。

相关文章:

寄存器、缓存、内存之间的关系和区别

https://blog.csdn.net/m0_46761060/article/details/124689209 目录 关系1、寄存器2、缓存&#xff08;Cache&#xff09; 2.1、寄存器和缓存的区别2.2、一级缓存和二级缓存3、内存 3.1、只读存储器 ROM&#xff08;Read Only Memory&#xff09;3.2、随机存储器 RAM&#xf…...

音视频项目—基于FFmpeg和SDL的音视频播放器解析(二十二)

介绍 在本系列&#xff0c;我打算花大篇幅讲解我的 gitee 项目音视频播放器&#xff0c;在这个项目&#xff0c;您可以学到音视频解封装&#xff0c;解码&#xff0c;SDL渲染相关的知识。您对源代码感兴趣的话&#xff0c;请查看基于FFmpeg和SDL的音视频播放器 如果您不理解本…...

单片机AT89C51直流电机控制电路PWM设计

wx供重浩&#xff1a;创享日记 对话框发送&#xff1a;直流电机 获取论文报告源码源程序原理图 此文将介绍一种直流电机&#xff0c;详细阐述了用单片机输出口所给占空比的不同实现电机的调速的设计方法&#xff1b;着重讨论L298用于电机驱动时特有的优势。直流电机调速具有…...

Python面经【2】

一、赋值、浅拷贝和深拷贝的区别 赋值 在python中&#xff0c;对象的赋值就是简单的对象引用。 1. a [1,2,"hello",[python, C]]2. b a 在上述情况下&#xff0c;a和b是一样的&#xff0c;它们指向同一片内存&#xff0c;b不过是a的别名&#xff0c;是引用。 赋值…...

邮政快递查询,邮政快递单号查询,用表格导出查询好的物流信息

批量查询邮政快递单号的物流信息&#xff0c;以表格的形式导出查询好的物流信息。 所需工具&#xff1a; 一个【快递批量查询高手】软件 邮政快递单号若干 操作步骤&#xff1a; 步骤1&#xff1a;运行【快递批量查询高手】软件&#xff0c;并登录 步骤2&#xff1a;点击主界…...

【经典小练习】输出文件路径名

文章目录 &#x1f339;问题✨思路&#x1f354;代码&#x1f6f8;读取文件&#xff0c;并把文件名保存到文件中 对指定目录下的所有 Java 文件进行编译、打包等处理&#xff1b; 查找指定目录下所有包含特定字符串的 Java 文件&#xff1b; 统计指定目录下所有 Java 文件的行数…...

【Python】【Torch】神经网络中各层输出的特征图可视化详解和示例

本文对神经网络各层特征图可视化的过程进行运行示例&#xff0c;方便大家使用&#xff0c;有助于更好的理解深度学习的过程&#xff0c;尤其是每层的结果。 神经网络各层特征图可视化的好处和特点如下&#xff1a; 可视化过程可以了解网络对图像像素的权重分布&#xff0c;可…...

接口测试学习路线

接口测试分为两种&#xff1a; 测试外部接口&#xff1a;系统和外部系统之间的接口 如&#xff1a;电商网站&#xff1a;支付宝支付 测试内部接口&#xff1a;系统内部的模块之间的联调&#xff0c;或者子系统之间的数据交互 测试重点&#xff1a;测试接口参数传递的正确性&…...

蓝桥杯官网算法赛(蓝桥小课堂)

问题描述 蓝桥小课堂开课啦&#xff01; 海伦公式&#xff08;Herons formula&#xff09;&#xff0c;也称为海伦-秦九韶公式&#xff0c;是用于计算三角形面积的一种公式&#xff0c;它可以通过三条边的长度来确定三角形的面积&#xff0c;而无需知道三角形的高度。 海伦公…...

求集合的笛卡尔乘积

求集合的笛卡尔乘积 一&#xff1a;【实验目的】二&#xff1a;【实验内容】三&#xff1a;【实验原理】四&#xff1a;代码实现&#xff1a; 一&#xff1a;【实验目的】 通过编实现给定集合A和B的笛卡尔积CAA,DAB,EBA,FAAB,GA(A*B&#xff09;. 二&#xff1a;【实验内容】…...

Linux系统常用指令大全(图文详解)

目录 前言 一、UNIX的登录与退出 1、登录 &#xff08;1&#xff09;执行格式&#xff1a; &#xff08;2&#xff09;步骤 2、退出 二、UNIX命令格式 三、常用命令 1、目录操作 &#xff08;1&#xff09;显示目录文件 ls &#xff08;2&#xff09;建新目录 …...

基于PLC触摸屏控制的伺服电机绕线机

摘 要 绕线机是专供连续绕制多圈电位器绕阻的专用机床设备。本文介绍了采用 PLC作为主控制机器&#xff0c;触摸屏作为操作界面&#xff0c;步进电机、伺服电机驱动的绕线机系统。描述 了触摸屏的原理、分类和触摸屏人机界面的控制方式&#xff0c;完成了触摸屏人机界面设计。…...

1.8 C语言之参数传递

1.8 C语言之参数传递 一、参数传递 一、参数传递 在C语言中&#xff0c;所有的参数传递都是值传递&#xff0c;也就是说&#xff0c;传递给被调用函数的参数值存放在临时变量中&#xff0c;而不是存放在原来的变量中。这与其他语言的引用传递有所不同。在C语言中&#xff0c;被…...

【Linux】进程间通信——system V共享内存、共享内存的概念、共享内存函数、system V消息队列、信号量

文章目录 进程间通信1.system V共享内存1.1共享内存原理1.2共享内存数据结构1.3共享内存函数 2.system V消息队列2.1消息队列原理 3.system V信号量3.1信号量原理3.2进程互斥 4.共享内存的使用示例 进程间通信 1.system V共享内存 1.1共享内存原理 共享内存区是最快的IPC形式…...

【黑马甄选离线数仓day05_核销主题域开发】

1. 指标分类 ​ 通过沟通调研&#xff0c;把需求进行分析、抽象和总结&#xff0c;整理成指标列表。指标有原子指标、派生指标、 衍生指标三种类型。 ​ 原子指标基于某一业务过程的度量值&#xff0c;是业务定义中不可再拆解的指标&#xff0c;原子指标的核心功能就是对指标…...

使用gin 代理 web网页

问web项目的代理&#xff0c;业界常用的方案是nginx做代理&#xff0c;这个是网上最多资料的。 因为我需要做自己的流量转发&#xff0c;也就是所有访问都要经过我的一个流量分发微服务&#xff0c;这和nginx作用冲突了。如果再加个nginx来做第一层方向代理和网页的静态资源代…...

计算器的模拟实现

计算器的模拟实现 一、实验题目&#xff1a;计算器二&#xff1a;实验目的&#xff1a;三&#xff1a;实验内容与实现1&#xff1a;【实验内容】2&#xff1a;【实验实现】1.计算器界面的实现&#xff0c;如下图所示&#xff1a;2&#xff1a;各项功能的实现&#xff0c;如下图…...

CentOS7搭建smb服务器

安装smb sudo yum install samba samba-client samba-common配置smb vim /etc/samba/smb.conf [shared] path /path/to/shared/folder writable yes browsable yes guest ok yes valid users yourname添加smb用户 sudo useradd youname sudo smbpasswd -a youname然后会…...

openEuler 22.03 LTS x86_64 cephadm 部署ceph 16.2.14 未完成 笔记

环境 准备三台虚拟机 10.47.76.94 node-1 10.47.76.95 node-2 10.47.76.96 node-3 下载cephadm [rootnode-1 ~]# yum install cephadm Last metadata expiration check: 0:11:31 ago on Tue 21 Nov 2023 10:00:20 AM CST. Dependencies resolved. Package …...

Java计算时间差,距结束还有几天几小时几分钟

文章目录 1、写法2、备份3、LocalDate、LocalDateTime、Date、String互转 1、写法 //静态方法&#xff0c;传入年月日时分秒 LocalDateTime startTime LocalDateTime.of(2023, 11, 22, 15, 09, 59); LocalDateTime endTime LocalDateTime.of(2023, 11, 30, 0, 0, 0); //计算…...

Android 12适配避坑指南:从Notification到PendingIntent的实战经验分享

Android 12适配深度解析&#xff1a;从核心机制到最佳实践 移动开发者的新挑战与机遇 每一次Android大版本更新都像一场技术狂欢&#xff0c;而Android 12的到来无疑为开发者们带来了全新的舞台。作为近年来变化最大的版本之一&#xff0c;Android 12不仅在UI设计上焕然一新&am…...

Hermes Agent,被中国团队实锤抄袭,回应方式更绝

2026年4月&#xff0c;GitHub 9万 Star 的 Hermes Agent 被中国团队锤了。抄没抄&#xff1f;我看完报告的结论是&#xff1a;抄了&#xff0c;而且锤得很实。事情经过Evolver 是谁做的2026年2月1日&#xff0c;中国开发者张昊阳&#xff08;ID: autogame-17&#xff0c;AI游戏…...

终极指南:使用ide-eval-resetter轻松重置JetBrains IDE试用期,实现开发自由

终极指南&#xff1a;使用ide-eval-resetter轻松重置JetBrains IDE试用期&#xff0c;实现开发自由 【免费下载链接】ide-eval-resetter 项目地址: https://gitcode.com/gh_mirrors/id/ide-eval-resetter 你是否曾经在项目关键时期遭遇JetBrains IDE试用期突然结束的尴…...

2026年3月亲测:GEO优化厂家实操分享

行业痛点分析在AI搜索流量占比超65%的2026年&#xff0c;全国GEO优化领域正面临三大核心挑战&#xff1a;地域精准度不足导致无效流量占比高达38%&#xff08;数据来源&#xff1a;中国互联网协会2026年Q1报告&#xff09;&#xff0c;平台适配滞后使企业错失72%的算法更新红利…...

云原生存储架构实践

云原生存储架构实践 1. 云原生存储架构的概念与价值 云原生存储架构是专为云环境设计的存储解决方案&#xff0c;具有弹性、可扩展、高可用等特性。随着容器化和微服务架构的普及&#xff0c;云原生存储已成为企业数据管理的重要组成部分。通过采用云原生存储架构&#xff0c;企…...

如何实现流水线函数_PIPELINED关键字与PIPE ROW应用

PIPE ROW 在 Oracle PL/SQL 中怎么写才不报错直接说结论&#xff1a;pipe row 只能在定义为 pipelined 的函数里用&#xff0c;且函数返回类型必须是已声明的集合类型&#xff08;比如 table of number&#xff09;&#xff0c;不能是 ref cursor 或标量。常见错误现象&#xf…...

Zend VM直接运行PHP代码出结果就不需要CPU了?

答案是&#xff1a;绝对需要 CPU。而且是非常大量的 CPU。 这是一个非常危险的误解。如果 Zend VM 运行不需要 CPU&#xff0c;那它就是在用“爱”发电&#xff0c;或者是在施展魔法。 真相是&#xff1a;Zend VM 本身就是一段巨大的、复杂的 C 语言程序。这段 C 语言程序必须被…...

EM32DX-E4 IO扩展模块实战:从寄存器配置到输入输出控制(附代码示例)

EM32DX-E4 IO扩展模块实战&#xff1a;从寄存器配置到输入输出控制 在工业自动化领域&#xff0c;IO扩展模块如同神经末梢&#xff0c;将控制系统的指令精准传递到每个执行单元。EM32DX-E4作为一款高性能的数字量输入输出扩展模块&#xff0c;其寄存器级的编程能力让工程师能够…...

吗替麦考酚酯Mycophenolate Mofetil预防实体器官移植排斥的长期移植物存活效果

在实体器官移植领域&#xff0c;移植物长期存活是评估免疫抑制治疗方案成功与否的核心指标。作为新一代免疫抑制剂&#xff0c;吗替麦考酚酯&#xff08;Mycophenolate Mofetil&#xff0c;MMF&#xff09;凭借其独特的药理特性&#xff0c;已成为预防器官移植排斥反应的标准药…...

从“闭源”Majestic看OpenIPC:一个开源IP摄像头固件的真实生态与DIY潜力

从“闭源”Majestic看OpenIPC&#xff1a;一个开源IP摄像头固件的真实生态与DIY潜力 当谈到开源IP摄像头固件时&#xff0c;大多数人会期待一个完全透明、可自由修改的解决方案。然而OpenIPC项目却呈现了一个更为复杂的现实——一个在开源理想与商业现实之间寻找平衡点的混合生…...