当前位置:  开发笔记 > 编程语言 > 正文

C中的算法比较,有什么区别?

如何解决《C中的算法比较,有什么区别?》经验,为你挑选了2个好方法。

第一个版本按顺序改变内存,因此最佳地使用处理器缓存.第二个版本使用它加载的每个缓存行中的一个值,因此它对于缓存使用来说是不重要的.

需要理解的是,缓存被划分为多行,每行都包含整个结构中的许多值.

第一个版本也可能由编译器优化,以使用更快的指令(SIMD指令).



1> Douglas Leed..:

第一个版本按顺序改变内存,因此最佳地使用处理器缓存.第二个版本使用它加载的每个缓存行中的一个值,因此它对于缓存使用来说是不重要的.

需要理解的是,缓存被划分为多行,每行都包含整个结构中的许多值.

第一个版本也可能由编译器优化,以使用更快的指令(SIMD指令).



2> 1800 INFORMA..:

这是因为第一个版本按照物理布局的顺序迭代内存,而第二个版本在内存中从数组中的一列跳到下一列.这将导致缓存抖动并干扰CPU的最佳性能,然后CPU必须花费大量时间等待缓存一次又一次地刷新.

推荐阅读
mobiledu2402852413
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有