首页 > 编程语言 > 详细

MFC的DLL中实现定时器功能

时间:2014-11-19 23:49:54      阅读:622      评论:0      收藏:0      [点我收藏+]
方法一:
创建一个线程, 反复读系统时间不就可以了? 如果定时要求不严,用Sleep就可以了。
DWORD WINAPI TimerThread(LPVOID pamaram) { UINT oldTickCount, newTickCount; oldTickCount = GetTickCount(); //获取的是毫秒数 while(TRUE) { while(TRUE) { newTickCount = GetTickCount(); // 获取的是毫秒数 if(newTickCount - oldTickCount >= 60000) { oldTickCount = newTickCount; break; } else SwitchToThread(); } // 60毫秒自动调用函数 SomeFun(); } return 0; }

  

方法二: DLL中的线程函数可以象这样使用Timer
UINT ThreadProc(LPVOID)
{

SetTimer(NULL, 1, 5000, NULL);
MSG msg;
// PeekMessage 强制系统为该线程建立消息栈
PeekMessage(&msg, NULL, NULL, NULL, FALSE);
while (GetMessage(&msg, NULL, NULL, NULL))
{
switch (msg.message)
{
case WM_TIMER:
{
// 这里每5秒钟执行一次
}
break;
}
//TranslateMessage(&msg);
//DispatchMessage(&msg);
}
KillTimer(NULL, 1);
return 0;
}

  

DWORD tidTimer;
UINT uElapse;
 
unsigned __stdcall TimerThreadProc(void *param)
{
    MSG msg;
    UINT_PTR hTimer;
 
    if ((hTimer = SetTimer(NULL, NULL, uElapse, 0)) == 0)
        MessageBox(NULL, L"Set Timer failed.", L"Error", MB_OK);
    while (GetMessage(&msg, NULL, 0, 0))
    {
        switch(msg.message)
        {
        case WM_TIMER:
            //...
            break;
 
        default:
            break;
        }
    }
    if (hTimer)
        KillTimer(NULL, hTimer);
    return 0;
}
 
_beginthreadex(NULL, 0, TimerThreadProc, NULL, 0, &tidTimer);
 
...
 
PostThreadMessage(tidTimer, WM_TIMER, 0, 0); //随后的某个事件处理中启动定时器

  

MFC的DLL中实现定时器功能

原文:http://www.cnblogs.com/renyuan/p/4109384.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!