VC获取系统时间、程序运行时间(精确到秒,毫秒)的五种方法

本文转自:http://blog.const.net.cn/a/16370.htm
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 是个结构体
含:年,月,日,周几,小时,分,秒,毫秒。
 
 
最近使用了测试程序达到微秒级的方法:
/////////////////////////////////////////////////
#include <iostream>
#include <windows.h>
using namespace    std;
////////////////////////////////////////////////
void main()
{
    _LARGE_INTEGER time_start;    /*开始时间*/
    _LARGE_INTEGER time_over;        /*结束时间*/
    double dqFreq;                /*计时器频率*/
    LARGE_INTEGER f;            /*计时器频率*/
    QueryPerformanceFrequency(&f);
    dqFreq=(double)f.QuadPart;
    QueryPerformanceCounter(&time_start);
    Sleep(1000);/*循环耗时*/
    QueryPerformanceCounter(&time_over); 
    cout<<((time_over.QuadPart-time_start.QuadPart)/dqFreq)<<endl;//单位为秒,精度为1000 000/(cpu主频)微秒
}
但是此方法也存在问题。详见:
http://blog.csdn.net/hailongchang/article/details/1444365
 
 
 

你可能感兴趣的:(VC获取系统时间,程序运行时间精确到秒,毫秒的五种方法)