cpu执行指令需要相应的数据,而这些数据大都来源于内存中,但是连续的读取内存会产生大量性能上的损失,所以就有了cpu缓存机制,现代cpu的性能指标不仅包含核数、电压,缓存能力也是一大重要的指标,缓存越大,一次能够读取的数据就越多。
缓存命中:当cpu执行的数据不在缓存中时,就会从内存中抓取需要的数据到自己缓存中,该数据在内存中上下连续的数据也会被抓取到缓存中,抓取的量取决于cpu的缓存能力,
执行完当前的指令,cpu跳转到下一条指令,开始判断执行该指令所需的数据是否在缓存中,如果在,就直接取用,称为缓存命中,如果不在,就清空当前的缓存,重新去内存中抓取。
在写代码时,尽量使用如数组之类的数据结构,其在内存中的存放是连续的,可以同时被抓取到cpu的缓存中,对于连续的操作,如遍历等,就可以在很大程度上提升缓存命中的次数,这也是为什么如果内存断块太多的时候需要进行压缩的原因之一。
ps:一边想一边打,留作记忆,如果有什么错误不当的地方,欢迎指出