繁体   English   中英

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

[英]std::chrono::high_resolution_clock - time measurement

我正在学习<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个滴答。

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

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

这是<chrono>的视频教程。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM