加法与比较
addition vs comparison
本文关键字:比较 更新时间:2023-10-16
假设我有一个包含 1,000,000 个元素的数组,其中大约 90% 的 0 和 10% 的 1。
为了数1s,我可以做
sum=0;
for(int i=0;i<size;i++) {
sum+=x[i]
}
但我认为也许比较比加法便宜,所以这会更好。
sum=0;
for(int i=0;i<size;i++) {
if(x[i]==1)
sum++;
}
但我不确定。哪一个更快?
如果不尝试一下,很难说哪一个会更快,但是由于流水线和分支预测,即使是没有分支的稍慢的指令通常也会更快。
在您的情况下,分支预测器在 90% 的时间内都是错误的,从而大大降低了速度。
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么比较运算符如此快速
- 我可以使用 g++ 进行三种比较 (<=>) 吗?
- 比较字符数组
- 将模板化的类型与C++中的某些类/类型进行比较
- C++自定义比较函数
- 如何比较自定义类的std::变体
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- std::设置自定义比较器
- 布尔比较运算符是如何在C++中工作的
- C++将目录中的所有文件与::filesystem进行比较
- shell排序中的交换和比较
- 如何在C++中比较两个char数组
- catch框架有没有办法比较流或文件
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 智能指针作为无序映射键,并通过引用进行比较
- 比较if语句中的数组值和int值
- 对于循环变体比较
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- 比较两个大小不等的映射c++