使用cin时如何使用clock()测量时间?

时间:2019-03-24 10:27:03

标签: c++

我需要使用clock()函数来测量程序的执行时间。整个算法由一个字符的输入组成。

我在这里找到了如何使用clock()来测量时间:How to use clock() in C++

#include <cstdio>
#include <ctime>

int main() {
    std::clock_t start;
    double duration;

    start = std::clock();

    std::cout << "Press a key followed by ENTER: ";
    char c;
    cin >> c;

    duration = ( std::clock() - start ) / (double) CLOCKS_PER_SEC;

    std::cout<<"printf: "<< duration <<'\n';
}

程序始终输出0。这是因为执行cin时没有处理器计数吗?我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

为此使用std::chrono工具:

#include <chrono>

// ...

auto start = std::chrono::steady_clock::now();

std::cout << "Press a key followed by ENTER: ";
char c;
std::cin >> c;

std::chrono::nanoseconds elapsed_ns = std::chrono::steady_clock::now() - start;
std::cout << "This took " << elapsed_ns.count() << " nanoseconds.\n";