计算程序运行时长:
1. 添加定时器ON_WM_TIMER()
初始化:
m_dwStartTime = GetCurrentTime();
SetTimer(1, 1000, NULL);
void CVPNDialerDlg::OnTimer(UINT_PTR nIDEvent) { // TODO: 在此添加消息处理程序代码和/或调用默认值 DWORD dwTime = GetCurrentTime() - m_dwStartTime; CString str, str1; str1.Format("运行时间:%02d:", dwTime / 3600000); dwTime %= 3600000; str = str1; str1.Format("%02d:", dwTime / 60000); dwTime %= 60000; str += str1; str1.Format("%02d", dwTime / 1000); str += str1; m_StatBar.SetText(str, 4, 0); CDialogEx::OnTimer(nIDEvent); }
1. 用CTime类(获取系统当前时间,精确到秒)
//获取系统时间 CTime sTmp = CTime::GetCurrentTime(); CString sTime = sTmp.Format("%Y-%m-%d %H:%M:%S"); //%Y四位年;%y2位年
(1).从CTime中提取年月日时分秒
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为星期六
(2).计算两段时间的差值,可以使用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();//获取总共有多少秒
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;
GetLocalTime(&st);
CString strDate,strTime;
strDate.Format("%4d-%2d-%2d",st.wYear,st.wMonth,st.wDay);
strTime.Format("%2d:%2d:%2d",st.wHour,st.wMinute,st.wSecond) ;
3.使用GetTickCount()或GetCurrentTime(),返回毫秒数
GetTickCount()和GetCurrentTime()都只精确到55ms(1个tick就是55ms)。
如果要精确到毫秒,应该使用timeGetTime函数或QueryPerformanceCounter函数
//获取系统运行时间
DWORD dwTime = GetCurrentTime() - m_dwStartTime;
CString str, str1;
str1.Format("运行时间:%02d:", dwTime / 3600000);
dwTime %= 3600000;
str = str1;
str1.Format("%02d:", dwTime / 60000);
dwTime %= 60000;
str += str1;
str1.Format("%02d", dwTime / 1000);
str += str1;
4.使用time_t time( time_t * timer ) 仅使用C标准库(精确到秒)
得到从标准计时点(一般是1970-01-01 00:00:00)到当前时间的秒数
计算时间差: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 精度很高
GetSystemTime返回的是格林威志标准时间
VOID GetSystemTime(
LPSYSTEMTIME lpSystemTime // address of system time structure
);
版权声明:本文为博主原创文章,未经博主允许不得转载。