std :: chrono :: high_resolution_clock - 时间测量

时间:2017-04-05 20:25:46

标签: c++ time chrono

我正在学习< chrono>现在,我不明白一件事。

#include <iostream>
#include <chrono>

int main()
{
    auto t1 = std::chrono::high_resolution_clock::now();
    int a = 0;
    auto t2 = std::chrono::high_resolution_clock::now();
    auto result = t2 - t1;
    std::cout << result.count() << std::endl;
    return 0;
}

在这种情况下,“结果”的值等于“0”。

#include <iostream>
#include <chrono>

int main()
{
    auto t1 = std::chrono::steady_clock::now();
    int a = 0;
    auto t2 = std::chrono::steady_clock::now();
    auto result = t2 - t1;
    std::cout << result.count() << std::endl;
    return 0;
}

在这种情况下,“结果”等于“5500”。

我做错了吗?

1 个答案:

答案 0 :(得分:5)

没有。只是不同的时钟可以有不同的精度,如此短的时间可能不会超过1个时钟滴答。

您可以通过检查clock::duration::period::numclock::duration::period::den来了解时钟的精确度。

此外,<chrono>的某些实施多年来一直存在“实施质量”问题。因此,当您切换编译器甚至同一编译器的版本时,您的体验可能会发生变化。如果您可以使用最新版本的编译器,那么您的体验通常会更好。

Here is a video tutorial for <chrono>.

相关问题