| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 894 人关注过本帖
标题:为什么多次用clock()测同一段程序的时间不一样?
只看楼主 加入收藏
buddy0112
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2008-6-17
收藏
 问题点数:0 回复次数:2 
为什么多次用clock()测同一段程序的时间不一样?
#include <time.h>
#include <stdio.h>
int main(void)
{       clock_t t_start;   /* start time when test starts */   
    clock_t t_end;     /* end time when test ends */         
    t_start = clock(); /* get start time */         /* test code */  
     要执行的程序A
    t_end = clock();   /* get end time */         /* display result */         
    printf("time: %.9f s\n", (double)(t_end-t_start)/CLOCKS_PER_SEC);         
    return 0;
}
我把clock()加到程序当中测试程序中一段的运行时间,所有的初始数据都不变,输入的值也都相同,可为什么最后得到的时间总是不一样?如果有小的差别可以接受,但问题是差别相差比较大,比如,对于程序A,我第一次测可能是30毫秒,第二次就会是17毫秒,第三次就是10毫秒,第四次就是9.1..毫秒,8.3..毫秒等等等,时间不断减少,但是相差越来越小.太奇怪了,但也不是所有的程序都有这个问题,我有想会不会计算机内部有什么记忆的东西,使得相同输入对应的有些运算\附值给简化了.请教一下大家有没有什么想法?有没有遇到过类似的问题?谢谢
搜索更多相关主题的帖子: clock 时间 
2008-10-20 17:01
Knocker
Rank: 8Rank: 8
等 级:贵宾
威 望:47
帖 子:10454
专家分:603
注 册:2004-6-1
收藏
得分:0 
去看看什么叫多任务与单任务

九洲方除百尺冰,映秀又遭蛮牛耕。汽笛嘶鸣国旗半,哀伤尽处是重生。     -老K
治国就是治吏。礼义廉耻,国之四维。四维不张,国之不国。   -毛泽东
2008-10-20 18:27
buddy0112
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2008-6-17
收藏
得分:0 
我不知道我的理解对不对.我试着在关掉其他没用进程(比如网页,文件夹等)的情形下只留VC,再测时间,发现测出的时间少了很多,而且多次测试都基本上相差不大了.是这个问题吗?谢谢
2008-10-21 22:13
快速回复:为什么多次用clock()测同一段程序的时间不一样?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.038233 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved