免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1908 | 回复: 5
打印 上一主题 下一主题

[C] 求助:测试运行时间 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-12 13:55 |只看该作者 |倒序浏览
代码如下:
clock_t time_start,time_end;
time_start = clock();
sleep(5);
time_end   = clock();
printf("time_start: %f \ntime_end: %f \nDid nothing in %f seconds\n",(double)time_start,(double)time_end,(time_end - time_start)/CLOCKS_PER_SEC);
我运行的结果总为:
time_start: 10000.000000
time_end: 10000.000000
Did nothing in -1.979256 seconds

请问这是什么原因?如何解决

[ 本帖最后由 shisanlangd 于 2008-6-12 13:59 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-06-12 14:01 |只看该作者
晕死,下次一次写清楚,

省得关了再开

论坛徽章:
0
3 [报告]
发表于 2008-06-12 14:08 |只看该作者
请先查一下clock_t到底是什么类型

论坛徽章:
0
4 [报告]
发表于 2008-06-12 14:17 |只看该作者
我看没人理我才改了一下
这个实例应该没问题,我测试运行时,确不行,想问问是不是和我的系统有关

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
5 [报告]
发表于 2008-06-12 14:29 |只看该作者
sleep的参数是ms还是s

论坛徽章:
0
6 [报告]
发表于 2008-06-12 14:31 |只看该作者
应该是秒,我的sleep(5)会休息5秒,sleep(5000)会一直休息
我找到原因了,谢谢众cu友的回复。
clock计算的是CPU对进程的近似处理时间,你sleep后,进程已经不占用CPU时间,故start==end,end-start==0。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP