NFR*_*RCR 9 c++ windows winapi
操作系统:Windows 7
当将WinAPI Sleep()函数调用为Sleep(1)时,线程实际上会休眠15ms.我在循环中做了100次,总睡眠时间是1500毫秒而不是100毫秒.
这是常见的行为,还是我应该关注我的MOBO,CPU,Windows安装有什么问题?
编辑:如果可能的话,你可以运行这段代码并发布睡眠时间.我让我的一个朋友跑了这个,他实际上已经在1ms完成了所有这一切.
#include <iostream>
#include <ctime>
#include <Windows.h>
void test(void)
{
std::cout << "Testing 1ms sleep." << std::endl;
for (unsigned int i = 0; i < 10; i++)
{
std::clock_t startClocks = std::clock();
Sleep(1);
std::clock_t clocksTaken = std::clock() - startClocks;
std::cout << "Time: " << clocksTaken << "ms." << std::endl;
}
}
int main(void)
{
test();
std::cin.sync();
std::cin.get();
return 0;
}
Run Code Online (Sandbox Code Playgroud)
编辑2:似乎有些人获得1毫秒的原因是其他一些程序正在运行,将系统范围的计时器分辨率设置为1毫秒.默认情况下,Windows 7上的此值应为15.6毫秒.
我发现的有关 Windows 计时的最佳文章位于此处和此处。有用的部分是,一旦更改多媒体计时器分辨率(例如将timeBeginPeriod(1)更改为 1 毫秒),它也会影响睡眠命令,因为它通常会影响调度程序。也就是说,在非实时操作系统上实现 1 毫秒的精度是不可行的。
| 归档时间: |
|
| 查看次数: |
11662 次 |
| 最近记录: |