vc++高精度计时sleep
2021/9/6 12:36:49
本文主要是介绍vc++高精度计时sleep,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
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左右
这篇关于vc++高精度计时sleep的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用