我有一个使用 C 函数的简单基准测试clock()
函数。
start[timerId]=clock();
clock_t end;
float dif_sec;
end=clock();
dif_sec=((float)end-start[timerId])/CLOCKS_PER_SEC;
printf("%s: %f seconds\n", msg, dif_sec);
它在 Mac OS X 上以 32 位运行良好,但是当我以 64 位编译时,结果全错了。为什么?!
这是我从您的代码的纯 C 版本(MacOS X 10.5.8 - Leopard;MacBook Pro)中得到的:
#include <time.h>
#include <stdio.h>
int main(void)
{
clock_t start = clock();
clock_t end = clock();
float dif_sec = ((float)end-start)/CLOCKS_PER_SEC;
printf("%s: %f seconds\n", "difference", dif_sec);
printf("%s: %d\n", "CLOCKS_PER_SEC", CLOCKS_PER_SEC);
return(0);
}
这就是我编译并运行它的方式,得到的结果是:
Osiris JL: gcc -m32 -o xxx-32 xxx.c
Osiris JL: gcc -m64 -o xxx-64 xxx.c
Osiris JL: ./xxx-32
difference: 0.000006 seconds
CLOCKS_PER_SEC: 1000000
Osiris JL: ./xxx-64
difference: 0.000009 seconds
CLOCKS_PER_SEC: 1000000
Osiris JL: ./xxx-64
difference: 0.000003 seconds
CLOCKS_PER_SEC: 1000000
Osiris JL: ./xxx-32
difference: 0.000003 seconds
CLOCKS_PER_SEC: 1000000
Osiris JL:
看起来还不错——也许相当快,但没关系;这是一台不错的新机器,连续进行两次系统调用不需要很长时间。