std::chrono
使用库:#include
std::chrono::time_point<std::chrono::high_resolution_clock> start = std::chrono::high_resolution_clock::now();//获取当前时间
func();
auto end = std::chrono::high_resolution_clock::now();
//auto end = std::chrono::system_clock::now();//两个函数均可,保持start和end一直即可;但是high_resolution_clock更准确
auto during = std::chrono::duration_cast<std::chrono::duration<double, std::ratio<1>>>(end - start);//获取函数运行时间
//auto during = std::chrono::duration_cast<std::chrono::duration<double>>(end - start);//获取函数运行时间,和上一个等价。duration类型如果只有一个参数的话默认单位是1秒,即std::ratio<1>
std::cout << during.count() << std::endl;//输出时间,单位是秒
auto during_ns = end - start;//不加转换,单位为ns。
std::cout << during_ns .count() << std::endl;/
输出:
during: 1.50898
during_ns: 1508979700
std::thread
使当前 线程休息:
std::this_thread::sleep_for(std::chrono::duration<double, std::ratio<1>>(1.5));//当前线程休息1.5秒
std::this_thread::sleep_for(std::chrono::duration<int, std::ratio<10>>(2));//当前线程休息20秒
std::this_thread::sleep_for(std::chrono::duration<double, std::ratio<1,2>>(2));//当前线程休息1秒
std::chrono::duration使用的默认单位是秒,std::ratio<1,2>可以用于给后面的具体的数值定义秒的单位,例如std::ratio<1,2>就是1/2=0.5s, 即后面数值是2,那么一共休息2*0.5=1s
三种时钟
std::chrono是C++11引入的日期时间处理库,其中包含3种时钟类:system_clock(系统时钟),steady_clock(稳定时钟),high_resolution_clock(高精度时钟);这三个时间类都提供了rep(周期)、period(单位比率)、duration(成员类型)。这三个时钟类都提供了一个静态成员函数 now() 用于获取当前时间,该函数的返回值是一个 time_point 类型。
原文链接:https://blog.csdn.net/weixin_42322256/article/details/124060870
计时器精度问题
std::this_thread::sleep_for(std::chrono::milliseconds(milliseconds));
c++计时器普通调用方式是有最小精度的,哪怕设置sleep(1),实际上也是休息最小的精度。这个最小值一般是15ms.
即sleep(1) = sleep(15);
下面是避免这种问题的方式
timeBeginPeriod(1); //设置精度为1毫秒
std::this_thread::sleep_for(std::chrono::milliseconds(1));//实际休眠时间为1ms
timeEndPeriod(1);//结束精度设置