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:中國標準時間 %% % 字元。 含:年,月,日,周幾,小時,分,秒,毫秒。[喝小酒的網摘]http://blog.const.net.cn/a/16370.htm