Linux clock_t和timeb ftime计时为什么差别那么大?

joyeewen 2011-09-05 10:23:56

clock_t start_timer, end_timer;
struct timeb start_time, finish_time;
ftime(&start_time);
start_timer = clock();
//在这调用函数做一些事
end_timer = clock();
ftime(&finish_time);
double duration = finish_time.time * 1000 + finish_time.millitm - (start_time.time * 1000 + start_time.millitm);
cout << "Time: " << ((end_timer - start_timer) / double(CLOCKS_PER_SEC)) << endl;
cout << "Time: " << duration << endl;

输出结果是:
Time: 1.31
Time: 2097

为什么会这样?不是两个时间应该是差不多的,现在一个是1秒多,一个是2秒。
我是在ubuntu下写的代码,请各位指教。
...全文
459 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
2011-09-05
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 joyeewen 的回复:]
那就是说clock要比ftime更准确些?
[/Quote]
两个测得的是不同的量,用途不同,没有哪个更准确的说法。

比如测 I/O 这些几乎不耗 CPU 时间的任务就不能用 clock。
joyeewen 2011-09-05
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 hpsmouse 的回复:]

clock 得到的是进程占用的 CPU 时间,ftime 得到的是当前的实际时间。
[/Quote]
那就是说clock要比ftime更准确些?
jackyjkchen 2011-09-05
  • 打赏
  • 举报
回复
中间CPU的调度会造成影响
2011-09-05
  • 打赏
  • 举报
回复
clock 得到的是进程占用的 CPU 时间,ftime 得到的是当前的实际时间。
joyeewen 2011-09-05
  • 打赏
  • 举报
回复
大家顶下,马上结贴,虽然分不多。

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧