Chinaunix首页 | 论坛 | 博客
  • 博客访问: 105404074
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: LINUX

2008-05-29 13:10:31

作者: theset  出自:
平时写测试程序的时候常常要计算程序执行的时间,尤其是最近练习Intel多核编程时,需要判断打开openmp参数与否的执行时间的比较。

通常代码是这样写的:
#include
clock_t start, stop;
....
start = clock();
do_something();
stop = clock();
printf("%f", (double)(stop-start)/1000.0) ;
.....

或者是求当前时间的秒值:

double t = (double) clock()/1000.0;

但是这样的代码在Windows平台下是正确的(当然会这样写也是因为上Intel培训课时,例程都是这么写的),而到了Linux平台下,这个程序就错了,会发现时间一下多了1000倍。

事实上,clock_t的值转换为秒应该是除以CLOCKS_PER_SEC这个宏,而这个宏在Windows平台下是1000,而到了Linux平台下就是1000000了。

因此程序正确的写法是:
#include
clock_t start, stop;
....
start = clock();
do_something();
stop = clock();
printf("%f", (double)(stop-start)/(double)CLOCKS_PER_SEC) ;
.....

这样才能保证程序在跨平台移植时的正确性。
阅读(879) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~