首页 > 代码库 > MFC的DLL中实现定时器功能
MFC的DLL中实现定时器功能
方法一:
创建一个线程, 反复读系统时间不就可以了? 如果定时要求不严,用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中的线程函数可以象这样使用TimerUINT 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中实现定时器功能
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。