ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

vc++高精度计时sleep

2021-09-06 12:31:53  阅读:195  来源: 互联网

标签:高精度 t3 PER 耗时 sleep c++ INTEGER Sleep QueryPerformanceCounter


LARGE_INTEGER high_precision_sleep(LARGE_INTEGER preTime, unsigned long long   sleepTime) {
    LARGE_INTEGER t;
    QueryPerformanceCounter(&t);
    
    while(t.QuadPart-preTime.QuadPart<sleepTime)QueryPerformanceCounter(&t);
    //printf("sleepTime=%d\n", t.QuadPart-preTime.QuadPart);//调试时用来观察每次暂停时间。一般应略有不同才正确
    /*//这种方式与直接返回t精度差不多,但多了一个运算,划不来
preTime.QuadPart += sleepTime; return preTime;*/ return t; }

  使用方法:

LARGE_INTEGER freq,t0,t1,t3;

QueryPerformanceFrequency(&freq);//频率   计数/秒

 

//当前频率 TIMES_PER_SECOND 下间隔的计数
auto SLEEP_COUNT = freq.QuadPart / TIMES_PER_SECOND;

 

QueryPerformanceCounter(&t0);
QueryPerformanceCounter(&t3);
for (int i = 0; i < number; i++) {

   //do something

   

   srand(t3.LowPart);//srand()函数产生一个以当前时间开始的随机种子
  Sleep(rand() %20 );//TIMES_PER_SECOND=30,理论上每次Sleep(33.33ms),但不能Sleep(rand()%30),因为Sleep精度问题,可能实际上超过

  //BitBlt(dcMem, 0, 0, 1920, 1080, dcScreen, 0, 0, SRCCOPY);

  t3=high_precision_sleep(t3, SLEEP_COUNT);

}

QueryPerformanceCounter(&t1);

cout << "执行 "<< number << " 次, 耗时 " << (((t1.QuadPart - t0.QuadPart) * 1000000) / freq.QuadPart)<< " 微秒" << std::endl;

 

当TIMES_PER_SECOND=30,number=500时,理论耗时:

 

实际耗时:耗时 16668737 微秒、耗时 16668737 微秒、耗时 16667480 微秒...每次相差不大,在1ms左右

 

标签:高精度,t3,PER,耗时,sleep,c++,INTEGER,Sleep,QueryPerformanceCounter
来源: https://www.cnblogs.com/xhzxlqt/p/15233209.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有