打開main.c編譯運行,注意,打開main.c之后一定要將win32timer.c也加進工程中一起編譯,下面有圖。
在開發單片機、ARM以及Linux系統的程序時,因為硬件定時中斷的存在我們很方便構造出定時ISR,然而在VC6.0中,我們如何寫一個定時程序呢?
其實,就是timeSetEvent()這個函數的調用。這個函數的解釋見MSDN。詳細原理,請看我代碼中的注釋,我寫得很詳細了。
main.c
void myISR_Called_Per_1000ms(void);
int main(void)
{
/* 每1000ms調用一次myISR_Called_Per_1000ms */
UserTimerSet ( 1000, myISR_Called_Per_1000ms ) ;
while (cnt<10);
return 0;
}
void myISR_Called_Per_1000ms(void)
{
printf("The Program has run %ds/n",cnt++);
}
win32timer.h
//=======================
// win32timer.h
//=======================
#ifndef __WIN32TIMER_H__
#define __WIN32TIMER_H__
void UserTimerSet ( unsigned int uDelay, void (*UserFun)(void) ) ;
#endif // @ #ifndef __WIN32TIMER_H__
win32timer.c
#include <windows.h>
#include "win32timer.h"
#pragma comment(lib,"winmm.lib") //導入winmm.lib多媒體庫
/* 全局變量 */
HANDLE mainhandle; //主線程句柄
CONTEXT Context; //主線程切換上下文
static void (*TimerCallFun)(void); //聲明用戶調用函數指針
/* 函數聲明 */
static void __stdcall TimerISR(unsigned int uTimerID, unsigned int uMsg, unsigned long dwUser, unsigned long dw1, unsigned long dw2);
//======================================================================================
// 函數功能:用戶需要調用的定時器設置(初始化)函數
// 入口參數:uDelay:定時器定時時長,單位為ms
// void (*UserFun)(void):指向用戶函數 void fun (void) 的函數指針
// 返 回 值:無
//======================================================================================
void UserTimerSet ( unsigned int uDelay, void (*UserFun)(void) )
{
HANDLE cp,ct;
TimerCallFun = UserFun; //得到用戶被定時調用的函數的函數指針
Context.ContextFlags = CONTEXT_CONTROL;
cp = GetCurrentProcess(); //得到當前進程句柄
ct = GetCurrentThread(); //得到當前線程偽句柄
DuplicateHandle( cp, ct, cp, &mainhandle, 0, TRUE, 2 ); //偽句柄轉換,得到線程真句柄
/*模擬設置定時器中斷,開啟一個定時器線程*/
timeSetEvent( uDelay, 0, TimerISR, 0, TIME_PERIODIC );
/*如果需要取消定時器,則可以調用timeKillEvent()函數,詳見MSDN*/
}
//======================================================================================
// 函數功能:timeSetEvent需要定時調用的函數
// 入口參數:unsigned int uTimerID, unsigned int uMsg, unsigned long dwUser, unsigned long dw1, unsigned long dw2,詳見MSDN
// 返 回 值:無
//======================================================================================
static void __stdcall TimerISR(unsigned int uTimerID, unsigned int uMsg, unsigned long dwUser, unsigned long dw1, unsigned long dw2)
{
SuspendThread(mainhandle); //中止主線程的運行,模擬中斷產生.但沒有保存寄存器
GetThreadContext(mainhandle, &Context); //得到主線程上下文,為切換任務做準備
//===========================================================================================
(*TimerCallFun)(); //或者TimerCallFun(); ―――― 用戶自定義實現的中斷調用
//===========================================================================================
ResumeThread(mainhandle); //模擬中斷返回,主線程得以繼續執行
}
運行結果
新聞熱點
疑難解答
圖片精選