CPU--cache和register的区别

cache:

为高速数据缓冲区,包含已经被发射到储存单元二还没有完成的储存操作的地址和数据,因为这些数据经常使用,保存在cache中比访问内存中速度要快,

使用的是SRAM作为物理存储介质,SRAM是门电路组成D锁存器组成的,不需要提供电流不停的去刷新数据,

register:

register是CPU拥有的一小块数据空间,也是CPU能直接操作的数据,操作指令空间,寄存器的基本单元是 由CMOS传输门和CMOS反相器组成D触发器。

下面为操作系统中优化程序性能的一点总结:

因为读写相关性会需要加载单元(register)去对比存储单元缓冲区中数据是否为同一个地址空间(当内存读的结构依赖于一个最近的内存写的情况代码时候)。

不同的源和目的地址,加载和存储操作可以使用流水线操作技术,而当源和目(s_data and load指令之间数据)的地址相同的时候,复杂的操作(左边)作为关键路径,没办法让多处理单元独立处理(需要验证地址是否相同),需要耗费更多的时间周期!

通俗的总结一下

1. 寄存器是中央处理器内的组成部份。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。在中央处理器的控制部件中,包含的寄存器有指令寄存器(IR)和程序计数器(PC)。在中央处理器的算术及逻辑部件中,包含的寄存器有累加器(ACC)。
2. 内存包含的范围非常广,一般分为只读存储器(ROM)、随机存储器(RAM)和高速缓存存储器(cache)。
3. 寄存器是CPU内部的元件,寄存器拥有非常高的读写速度,所以在寄存器之间的数据传送非常快。
4. Cache :即高速缓冲存储器,是位于CPU与主内存间的一种容量较小但速度很高的存储器。由于CPU的速度远高于主内存,CPU直接从内存中存取数据要等待一定时间周期,Cache中保存着CPU刚用过或循环使用的一部分数据,当CPU再次使用该部分数据时可从Cache中直接调用,这样就减少了CPU的等待时间,提高了系统的效率。Cache又分为一级Cache(L1 Cache)和二级Cache(L2 Cache),L1 Cache集成在CPU内部,L2 Cache早期一般是焊在主板上,现在也都集成在CPU内部,常见的容量有256KB或512KB L2 Cache。
总结:大致来说数据是通过内存-Cache-寄存器,Cache缓存则是为了弥补CPU与内存之间运算速度的差异而设置的的部件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

完颜振江

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值