永发信息网

关于C++的一个延时循环(会的看看,不会的可以学习下)

答案:2  悬赏:40  手机版
解决时间 2021-03-29 15:36
  • 提问者网友:wodetian
  • 2021-03-28 19:53
关于C++的一个延时循环(会的看看,不会的可以学习下)
最佳答案
  • 五星知识达人网友:迷人又混蛋
  • 2021-03-28 20:20
C/C++中的计时函数是clock(),而与其相关的数据类型是clock_t。在MSDN中,查得对clock函数定义如下: clock_t clock(void) ; 这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数,在MSDN中称之为挂钟时间(wal-clock)。其中clock_t是用来保存时间的数据类型,在time.h文件中,我们可以找到对它的定义: #ifndef _CLOCK_T_DEFINED typedef long clock_t; #define _CLOCK_T_DEFINED #endif 很明显,clock_t是一个长整形数。在time.h文件中,还定义了一个常量CLOCKS_PER_SEC,它用来表示一秒钟会有多少个时钟计时单元,其定义如下: #define CLOCKS_PER_SEC ((clock_t)1000) 可以看到每过千分之一秒(1毫秒),调用clock()函数返回的值就加1。下面举个例子,你可以使用公式clock()/CLOCKS_PER_SEC来计算一个进程自身的运行时间: void elapsed_time() { printf("Elapsed time:%u secs.\n",clock()/CLOCKS_PER_SEC); } 当然,你也可以用clock函数来计算你的机器运行一个循环或者处理其它事件到底花了多少时间: #include “stdio.h” #include “stdlib.h” #include “time.h” int main(void) { long i = 10000000L; clock_t start, finish; double duration; printf( "Time to do %ld empty loops is ", i ; start = clock(); while( i-- ; finish = clock(); duration = (double)(finish - start) / CLOCKS_PER_SEC; printf( "%f seconds\n", duration ; system("pause"; } 在笔者的机器上,运行结果如下: Time to do 10000000 empty loops is 0.03000 seconds 上面我们看到时钟计时单元的长度为1毫秒,那么计时的精度也为1毫秒,那么我们可不可以通过改变CLOCKS_PER_SEC的定义,通过把它定义的大一些,从而使计时精度更高呢?通过尝试,你会发现这样是不行的。在标准C/C++中,最小的计时单位是一毫秒。
全部回答
  • 1楼网友:人類模型
  • 2021-03-28 21:55
clock函数是返回程序的运行cpu时间,俗称“滴答数”,至于clock() - start里理解,我初学时看到也想不明白,最后明白的时候总结出来,关键是要认清,clock()的返回值是会随程序的运行时间的增长而增长的,所以一开始取一个时间start = clock(),然后clock()会不断增加,直到clock() - start > delay,就说明延时期限已到,跳出while循环。 CLOCKS_PER_SEC是一个便于使clock_t和秒之间转换的宏,字面意思也就是 滴答数/秒,clock()返回的是滴答数,输入a秒以后a秒乘以这个宏就可以得到等量delay秒数的滴答数。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯