Ddr2,ddr3,ddr4内存条的读写速率
2016-03-03 15:50
204 查看
理论极限值是可以计算的:1333MHz * 64bit(单通道,双通道则128bit) / 8(位到字节单位转换) = 10.664GB/s。这只是理论,实际发挥还要看内存控制器,实际上1333单条跑出来的数据在7~9GB/s差不多了。
首先,实际中我没见过内存速度超过10GB/s的情况,不知道是不是题主你把单位弄错了?实际见过的像RamDisk之类的软件,连续读写能达到的速度也不过5~8GB/s左右,如果是随机读写,性能大概还要下降接近十分之一。
所以内存没你想的那么快。
其次,内存检测不是把内存读写一遍就完事,读写完还要检测读写数据是否一致,这些都是要通过CPU的ALU完成,CPU的负载会非常重,而且很多时候也并非是大块读写,而是4字节甚至单字节读写,这样算下来,为了检测一个字节的内存单元,CPU可能需要十几个到几十指令,这里还包含不少算数指令,速度很慢。
这样最终算下来,内存检测的速度大概在100MB/s或者更慢,这还没完,为了检测内存的每个bit是否正确,通常来说要擦写很多中不同的数据,比如uboot里的内存检测就写了好几次,如果以4字节16进制数来看,那么写入的东西包括:全0,全1,全5,全A,全F,基于地址的移位,地址值,地址值求反……
这还没完,还要检测物理地址的地址线是否有效,地址线可能会断开、互绕、短路等等,还有一堆堆的数字要写进去、读出来,有些地址线还可能把同一个内存位置错误的映射成两个不同的地址,因此写入的次序也有要求。
所以最终的结果就是内存检测的时间非常漫长,不亚于压缩一部像内存那么大的片子。
补充:以上仅限于用专门的内存检测工具测试的效果,PC机开机自检一般只做很简单的测试,速度很快。
相关文章推荐
- 如何在jmeter中调用自己写的java工具包
- cocoapods 安装
- 用链表实现栈
- Android网络下载图片Handler处理机制
- Activity生命周期
- UIScrollView(loading...)
- Lua学习笔记5:类及继承的实现
- 微信公众号 SDK
- STL_算法_01_查找算法
- Ajax
- 公共函数库的介绍与使用
- Animation动画详解(八)——PropertyValuesHolder与Keyframe
- ROM
- 关联其它表进行update数据
- .NET 4 协变和逆变理解
- linux 学习决心书
- HTTP基本原理(浏览器缓存)
- hibernate @Entity @Table 实体类中不可以随便添加与表字段不对应的get方法,如增加请加注解 @Transient
- hadoop 2.6 AbstractYarnScheduler源代码解析
- AMD规范