巧用CPU缓存优化代码:数组 vs. 链表(转)
2009-03-30 10:59
344 查看
一个常见的编程问题: 遍历同样大小的数组和链表, 哪个比较快? 如果按照大学教科书上的算法分析方法,你会得出结论,这2者一样快, 因为时间复杂度都是 O(n)。 但是在实践中, 这2者却有极大的差异。 通过下面的分析你会发现, 其实数组比链表要快很多。 首先介绍一个概念:memory hierarchy (存储层次结构),电脑中存在多种不同的存储器,如下表 CPU 寄存器 – immediate access (0-1个CPU时钟周期) CPU L1 缓存 – fast acces
相关文章推荐
- [编程技巧] 巧用CPU缓存优化代码:数组 vs. 链表
- 巧用CPU缓存优化代码: 数组VS链表
- [编程技巧] 巧用CPU缓存优化代码:数组 vs. 链表
- [编程技巧] 巧用CPU缓存优化代码:数组 vs. 链表
- 巧用CPU缓存优化代码:数组 vs. 链表(转)
- 巧用CPU缓存优化代码:数组 vs. 链表
- 【转】巧用CPU缓存优化代码:数组 vs. 链表
- 一道简单的acm题的三种解决方案(数组、单向链表、容器vector)与代码优化
- 【转载】利用CPU缓存的特性优化数据存储---数组vs链表
- 【代码优化】返回0长度数组或者集合
- 从缓存友好的角度分析数组和链表
- 数组仿真链表的优化
- C/C++代码被 VS 2010 优化掉了,如何关闭优化?
- 算法学习笔记之四:巧妙运用指针解决链表、字符串、数组等问题(同向双指针VS对向双指针)
- 代码优化:复制数组
- VS项目编译包含CUDA的静态库及在原项目中添加CUDA优化代码方法
- c语言-链表VS数组
- 从cpu和内存来理解为什么数组比链表查询快
- VS 优化C++代码几点注意事项
- 利用VS的代码优化和openmp并行计算提高程序运行速度