程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 用C++ Builder進行精確計時

用C++ Builder進行精確計時

編輯:關於C++

雖然Win95下可視化開發工具如VC、Delphi、C++ Builder等都有專用的定時器控件Timer,而且使用很方便,可以實現一定的定時功能,但最小計時精度僅為55ms,且定時器消息在多任務操作系統中的優先級很低,不能得到及時響應,往往不能滿足實時控制環境下的應用。不過Microsoft公司

在Win32 API函數庫中已經為用戶提供了一組用於高精度計時的底層函數,如果用戶使用得當,計時精度可到1ms。這個計時精度、對於一般的實時系統控制完全可以滿足要求。現將由C++ Builder 4.0提供的重新封裝後的一組與時間相關的主要接口函數(函數名、參數、功能與Win32 API基本相同)說明如下:

1.DWORD timeGetTime(void)

返回從Windows啟動開始經過的毫秒數。最大值為232,約49.71

天。

2.MMRESULT timeSetEvent(

  UINT uDelay,
   UINT uResolution,
   LPTIMECALLBACK lpTimeProc,
   DWORD dwUser,
   UINT fuEvent
   )

該函數設置一個定時回調事件,此事件可以是一個一次性事件或周期性事件。事件一旦被激活,便調用指定的回調函數,成功後返回事件的標識符代碼,否則返回NULL。參數說明如下:

uDelay:以毫秒指定事件的周期。

UResolution:以毫秒指定延時的精度,數值越小定時器事件分辨率越高。缺省值為1ms。

LpTimeProc:指向一個回調函數。

DwUser:存放用戶提供的回調數據。

FuEvent:指定定時器事件類型:

TIME_ONESHOT:uDelay毫秒後只產生一次事件

TIME_PERIODIC :每隔uDelay毫秒周期性地產生事件。

3.MMRESULT timeKillEvent(UINT uTimerID)

該函數取消一個指定的定時器回調事件。uTimerID標識要取消的事件(由timeSetEvent函數返回的標識符)。如果成功則返回TIMERR_NOERROR

,如果定時器時間不存在則返回MMSYSERR_INVALPARAM。

  void CALLBACK TimeProc(
   UINT uID,
   UINT uMsg,
   DWORD dwUser,
   DWORD dw1,
   DWORD dw2
   );

該函數是一個應用程序定義的回調函數,出現定時器事件時該函數被調用。TimeProc是應用程序定義的函數名的占位符。使用該函數時要注意的是,它只能調用以下有限的幾組API函數:PostMessage,timeGetSystemTime, timeGetTime, timeSetEvent,timeKillEvent,midiOutShortMsg, midiOutLongMsg,OutputDebugString。同時也不要使用完成時間很長的API函數,程序盡可能簡短。

使用以上一組函數就可以完成毫秒級精度的計時和控制(在C++Builder中使用時要將頭文件mmsystem.h加到程序中)。由於將定時控制精確到幾毫秒,定時器事件將占用大量的CPU時間和系統資源,所以在滿足控制要求的前提下,應盡量將參數uResolution的數值增大。而且定時器實時控制功能完成後要盡快釋放。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved