C++:计时器

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);//结束精度设置
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值