一直很困惑一个问题:
我设置了一个10秒的定时器,可是被调用的函数要花费30秒,
那待调用的函数第二次是什么时候调用的呢?
20秒, 40秒, 还是50秒呢....
所以我进行了实验.
我写了一个类 CExecSqlTimer, 这里类封装了.setitime.
这个类创建一个线程来调用待调用函数.
CExecSqlTimer *time = new CExecSqlTimer;
time->SetInterval( * );
time->Start();
待调用函数:
BOOL CExecSqlTimer::OnTimer()
{ static DWORD dwTick = ::GetTickCount();
static int i = ;
DWORD t = ::GetTickCount() - dwTick;
CString str;
str.Format(" 第 %d 次 %d ms调用.", i, t);
TRACE("%s\n", str);
Sleep();
str.Format(" 第 %d 次 %d ms 执行完.", i, ::GetTickCount() - dwTick);
TRACE("%s\n", str);
i++;
return TRUE;
}
关键看执行完代码:
第 次 ms调用.
第 次 ms 执行完.
第 次 ms调用.
第 次 ms 执行完.
第 次 ms调用.
第 次 ms 执行完.
第 次 ms调用.
第 次 ms 执行完.
第 次 ms调用.
第 次 ms 执行完.
第 次 ms调用.
第 次 ms 执行完.
第 次 ms调用.
第 次 ms 执行完.
事实就放在这里了哈~
想要10秒执行一次,那你就在函数里开个线程去处理你的内容把~