相关疑难解决方法(0)

如何暂停特定的时间?(Excel中/ VBA)

我有一个Excel工作表,其中包含以下宏.我想每秒循环一次,但如果我能找到这样做的功能,那就很危险.不可能吗?

Sub Macro1()
'
' Macro1 Macro
'
Do
    Calculate
    'Here I want to wait for one second

Loop
End Sub
Run Code Online (Sandbox Code Playgroud)

excel vba

99
推荐指数
9
解决办法
69万
查看次数

WinAPI Sleep()函数调用睡眠时间超过预期

操作系统: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毫秒.

c++ windows winapi

9
推荐指数
3
解决办法
1万
查看次数

标签 统计

c++ ×1

excel ×1

vba ×1

winapi ×1

windows ×1