【问题标题】:CLOCKS_PER_SEC in C language found the time.h libraryC语言中的CLOCKS_PER_SEC找到time.h库
【发布时间】:2018-07-24 14:39:23
【问题描述】:

CLOCKS_PER_SEC 是否因系统而异,或者对于操作系统而言是恒定的,还是取决于特定系统的处理器? 并且还帮我解释我的代码的输出......对吗??

#include<stdio.h>
#include<time.h>
int main()
{
int a;
long int b;
clock_t start, end;

start = clock();

//Code for which the time is to be calculated
for(a=0;;a++)
{
    if(a<0)
    {
        break;
    }
}
printf("int : %u\n",a);
for(b=0;;b++)
{
    if(b<0)
    {
        break;
    }
}
printf("long int :%u\n",b);
//code is over

end = clock();

//CLOCKS_PER_SECOND : the number of clock ticks per second
printf("Starting Time:%u\n",start);
printf("Ending Time:%u\n",end);
printf("CLOCKS_PER_SEC:%u",CLOCKS_PER_SEC);
printf("\nNumber of clock ticks:%u",(end - start));
printf("\nTotal time:%u",(double)(end - start)/CLOCKS_PER_SEC);
return 0;
}

输出:

int : 2147483648
long int :2147483648
Starting Time:0
Ending Time:9073
CLOCKS_PER_SEC:1000
Number of clock ticks:9073
Total time:1099511628
Process returned 0 (0x0)   execution time : 15.653 s
Press any key to continue.

【问题讨论】:

  • 您认为为什么将其定义为宏?当然,你不应该假设它在每个系统上都是一样的!
  • AFAIK,POSIX 将其定义为 1'000'000。所以你似乎在一个非 POSIX 系统上。
  • 顺便说一句,%u 是用于打印 double 的错误格式说明符。

标签: c clock


【解决方案1】:

CLOCKS_PER_SEC 是否因系统而异,或者对于操作系统而言是恒定的,还是取决于特定系统的处理器?

CLOCKS_PER_SEC 最终由编译器及其标准库实现决定,而不是操作系统。尽管机器、操作系统和其他因素会影响编译器提供的功能。

帮我解释一下我的代码的输出……对吗?

没有。 printf("\nTotal time:%u",(double)(end - start)/CLOCKS_PER_SEC); 正在使用 "%u" 打印 double@Felix Palmen

CLOCKS_PER_SEC 不一定是 unsigned
clock_t 不一定是 intRef
使用错误的 printf() 说明符会使输出无法提供信息。
提示:启用所有编译器警告。

转换为宽类型并使用匹配的打印说明符。

clock_t start
// printf("Starting Time:%u\n",start);
printf("Starting Time:%g\n", (double) start);

// printf("CLOCKS_PER_SEC:%u",CLOCKS_PER_SEC);
printf("CLOCKS_PER_SEC:%g\n", (double) CLOCKS_PER_SEC);

// printf("\nTotal time:%u",(double)(end - start)/CLOCKS_PER_SEC);
printf("Total time:%g\n",(double)(end - start)/CLOCKS_PER_SEC);

或者甚至考虑long double

long double t = (long double)(end - start)/CLOCKS_PER_SEC;
printf("Total time:%Lg\n", t);

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-05-23
    • 2012-06-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-07-24
    • 1970-01-01
    相关资源
    最近更新 更多