Pau*_*man 1 c++ time c++-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;
}
Run Code Online (Sandbox Code Playgroud)
在这种情况下,"结果"的值等于"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;
}
Run Code Online (Sandbox Code Playgroud)
在这种情况下,"结果"等于"5500".
难道我做错了什么?
不.只是不同的时钟可以有不同的精度,而如此短的时间可能不会超过1个时钟滴答.
您可以通过检查clock::duration::period::num和确定时钟的精度clock::duration::period::den.
此外,<chrono>多年来一些实施已经具有"实施质量"问题.因此,当您切换编译器甚至同一编译器的版本时,您的体验可能会发生变化.如果您可以使用最新版本的编译器,那么您的体验通常会更好.