1. 程式人生 > >VC獲取系統時間、程式執行時間(精確到秒,毫秒)

VC獲取系統時間、程式執行時間(精確到秒,毫秒)

1.使用CTime類(獲取系統當前時間,精確到秒)
CString str;
//獲取系統時間
CTime tm;
tm=CTime::GetCurrentTime();//獲取系統日期
str=tm.Format("現在時間是%Y年%m月%d日 %X");
MessageBox(str,NULL,MB_OK);

a,從CTimet中提取年月日時分秒 

 CTime t = CTime::GetCurrentTime(); 
  int d=t.GetDay(); //獲得幾號

  int y=t.GetYear(); //獲取年份

  int m=t.GetMonth(); //獲取當前月份

  int h=t.GetHour(); //獲取當前為幾時

  int mm=t.GetMinute(); //獲取分鐘

  int s=t.GetSecond(); //獲取秒

  int w=t.GetDayOfWeek(); //獲取星期幾,注意1為星期天,7為星期六

b,計算兩段時間的差值,可以使用CTimeSpan類,具體使用方法如下:

  CTime t1( 1999, 3, 19, 22, 15, 0 );

      CTime t = CTime::GetCurrentTime();

      CTimeSpan span=t-t1; //計算當前系統時間與時間t1的間隔

  int iDay=span.GetDays(); //獲取這段時間間隔共有多少天

  int iHour=span.GetTotalHours(); //獲取總共有多少小時

  int iMin=span.GetTotalMinutes();//獲取總共有多少分鐘

  int iSec=span.GetTotalSeconds();//獲取總共有多少秒

c,獲得當前日期和時間,並可以轉化為CString

  CTime tm=CTime::GetCurrentTime(); CString str=tm.Format("%Y-%m-%d");//顯示年月日

2.使用GetLocalTime:Windows API 函式,獲取當地的當前系統日期和時間 (精確到毫秒)


  此函式會把獲取的系統時間資訊儲存到SYSTEMTIME結構體裡邊


  typedef struct _SYSTEMTIME


  {


  WORD wYear;//年
  WORD wMonth;//月
  WORD wDayOfWeek;//星期:0為星期日,1為星期一,2為星期二……
  WORD wDay;//日
  WORD wHour;//時
  WORD wMinute;//分
  WORD wSecond;//秒
  WORD wMilliseconds;//毫秒
  }SYSTEMTIME,*PSYSTEMTIME;
例:
SYSTEMTIME st;
CString strDate,strTime;
GetLocalTime(&st);
strDate.Format("%4d-%2d-%2d",st.wYear,st.wMonth,st.wDay);
strTime.Format("%2d:%2d:%2d",st.wHour,st.wMinute,st.wSecond) ;
AfxMessageBox(strDate);
AfxMessageBox(strTime);

3.使用GetTickCount:從作業系統啟動到現在所經過(elapsed)的毫秒數,它的返回值是DWORD。(精確到毫秒)

//獲取程式執行時間
long t1=GetTickCount();//程式段開始前取得系統執行時間(ms)
Sleep(500);
long t2=GetTickCount();();//程式段結束後取得系統執行時間(ms)
str.Format("time:%dms",t2-t1);//前後之差即 程式執行時間
AfxMessageBox(str);
//獲取系統執行時間
long t=GetTickCount();
CString str,str1;
str1.Format("系統已執行 %d時",t/3600000);
str=str1;
t%=3600000;
str1.Format("%d分",t/60000);
str+=str1;
t%=60000;
str1.Format("%d秒",t/1000);
str+=str1;
AfxMessageBox(str);


4.使用time_t time( time_t * timer ) :   僅使用C標準庫(精確到秒)
得到從標準計時點(一般是1970年1月1日午夜)到當前時間的秒數  
  計算時間差:double difftime( time_t timer1, time_t timer0)
       struct tm *localtime(const time_t *timer);  取得當地時間,localtime獲取的結果由結構tm返回  
返回的字串可以依下列的格式而定:  
%a 星期幾的縮寫。Eg:Tue  
%A 星期幾的全名。 Eg: Tuesday  
%b 月份名稱的縮寫。  
%B 月份名稱的全名。  
%c 本地端日期時間較佳表示字串。  
%d 用數字表示本月的第幾天 (範圍為 00 至 31)。日期  
%H 用 24 小時制數字表示小時數 (範圍為 00 至 23)。  
%I 用 12 小時制數字表示小時數 (範圍為 01 至 12)。  
%j 以數字表示當年度的第幾天 (範圍為 001 至 366)。  
%m 月份的數字 (範圍由 1 至 12)。  
%M 分鐘。  
%p 以 ''AM'' 或 ''PM'' 表示本地端時間。  
%S 秒數。  
%U 數字表示為本年度的第幾周,第一個星期由第一個週日開始。  
%W 數字表示為本年度的第幾周,第一個星期由第一個週一開始。  
%w 用數字表示本週的第幾天 ( 0 為週日)。  
%x 不含時間的日期表示法。  
%X 不含日期的時間表示法。 Eg: 15:26:30  
%y 二位數字表示年份 (範圍由 00 至 99)。  
%Y 完整的年份數字表示,即四位數。 Eg:2008  
%Z(%z) 時區或名稱縮寫。Eg:中國標準時間  
%% % 字元。 

5.要獲取高精度時間,可以使用
    BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency)獲取系統的計數器的頻率
    BOOL QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)獲取計數器的值
    然後用兩次計數器的差除以Frequency就得到時間。

6.還有David的文章中提到的方法:
    Multimedia Timer Functions
    The following functions are used with multimedia timers.
    timeBeginPeriod/timeEndPeriod/timeGetDevCaps/timeGetSystemTime
    timeGetTime/timeKillEvent/TimeProc/timeSetEvent 精度很高 
Q:
GetTickCount()函式,說是毫秒記數,是真的嗎,還是精確到55毫秒?
A:
GetTickCount()和GetCurrentTime()都只精確到55ms(1個tick就是55ms)。如果要精確到毫秒,應該使用timeGetTime函式或QueryPerformanceCounter函式。具體例子可以參考QA001022 "VC++中使用高精度定時器"、QA001813 "如何在Windows實現準確的定時"和QA004842 "timeGetTime函式延時不準"。
Q:
vc++怎樣獲取系統時間,返回值是什麼型別的變數呢? 
A:
GetSystemTime返回的是格林威志標準時間 
VOID GetSystemTime( 
LPSYSTEMTIME lpSystemTime // address of system time structure 
); 
函式就可以獲得了,其中LPSYSTEMTIME 是個結構體 
含:年,月,日,周幾,小時,分,秒,毫秒。