-3
我正在根据收到的意见重新编写此问题。我有一个循环,运行300亿次,并为使用malloc()分配的内存块分配值;为什么C程序在循环包含条件时运行速度更慢
当循环包含一个条件时,它会比条件不存在时慢得多。查看以下情形:
情形A:条件存在且程序是缓慢(43秒)
情形B:条件是不存在,并且程序的速度要快得多(4秒)
// gcc -O3 -c block.c && gcc -o block block.o
#include <stdio.h>
#include <stdlib.h>
#define LEN 3000000000
int main (int argc, char** argv){
long i,j;
unsigned char *n = NULL;
unsigned char *m = NULL;
m = (unsigned char *) malloc (sizeof(char) * LEN);
n = m;
srand ((unsigned) time(NULL));
int t = (unsigned) time(NULL);
for (j = 0; j < 10; j++){
n = m;
for (i = 0; i < LEN; i++){
//////////// A: THIS IS SLOW
/*
if (i % 2){
*n = 1;
} else {
*n = 0;
}
*/
/////////// END OF A
/////////// B: THIS IS FAST
*n = 0;
i % 2;
*n = 1;
/////////// END OF B
n += 1;
}
}
printf("Done. %d sec \n", ((unsigned) time(NULL)) - t);
free(m);
return 0;
}
问候, KD
没有任何语境我们只能猜测。一个猜测是0被用作一些字符串的终止字符,但正如我们所说的,我们需要一些上下文。 – Gerhardh
千里眼科正在休产假。所有关于非工作代码的问题都必须附带[mcve]。管理层希望为造成的不便道歉。 –
发布我们可以运行和编译的最简化代码。如果你是对的,我预测很多投票。 –