clock() 函数始终返回 0

clock() function always returning 0

本文关键字:返回 函数 clock      更新时间:2023-10-16

可能的重复项:
C clock()函数只返回一个零

我运行了以下代码来测试 clock() 函数的工作。我在 ubuntu 12.04 上工作。

#include <stdio.h>
#include <time.h>
#include <iostream>
using namespace std;

double diffclock(clock_t clock1,clock_t clock2)
{
double diffticks=clock1-clock2;
double diffms=(diffticks*10)/CLOCKS_PER_SEC;
return diffms;
}
int main()
{
string name;
int i;
clock_t begin=clock();
cout << "Hi what is your name? ";
getline(cin, name);
clock_t end=clock();
cout << "Time elapsed: " << double(diffclock(end,begin)) << " ms"<< endl;
return 0;
}

但是,无论我花多少时间写下我的名字,经过的时间总是显示为0ms。

你能告诉我问题出在哪里吗?

clock() 返回自程序开始执行以来使用的刻度数。无需(在此特定示例中)获取clock_t begin值。

尝试打印出begin值和end值,看看它们是什么。它们可能都是 0 或接近 0,因为等待用户输入不会占用 CPU 时间。

无论哪种方式,我都推荐time()函数,因为您不需要即时报价精度。http://www.cplusplus.com/reference/clibrary/ctime/time/

我认为你应该使用 time() 函数。以下是它的工作原理: http://asust.in/007D您只需调用它,它就会返回自 Unix 纪元(1970 年 1 月 1 日)以来的秒数。

clock() 函数返回自程序启动以来的时钟周期数。在这里: http://asust.in/007E