C/C++ 獲取系統時間 到秒 || 到毫秒

string getNowSysTime(string &outPut) { char szBuf[256] = {0}; struct timeval tv; struct timezone tz; struct tm         *p; gettimeofday(&tv, &tz); p = localtime(&tv.tv_sec); snprintf(szBuf, 256, "%02d-%02d-%02d %02d:%02d:%02d",  p->tm_year + 1900, p->tm_mon + 1, p->tm_mday, p->tm_hour, p->tm_min, p->tm_sec); return outPut = szBuf; } string GetSysUsecTimeHMS() { char szBuf[256] = {0}; struct timeval tv; struct timezone tz; struct tm         *p; gettimeofday(&tv, &tz); p = localtime(&tv.tv_sec); snprintf(szBuf, 256, "%02d-%02d-%02d %02d:%02d:%02d.%06ld", p->tm_year + 1900, p->tm_mon + 1, p->tm_mday, p->tm_hour, p->tm_min, p->tm_sec, tv.tv_usec); return szBuf; }
gettimeofday是計算機函數,使用C語言編寫程序須要得到當前精確時間(1970年1月1日到如今的時間),或者爲執行計時,可使用gettimeofday()函數。
#include <sys/time.h>
int gettimeofday(struct  timeval*tv, struct timezone *tz);

其參數tv是保存獲取時間結果的結構體,參數tz用於保存時區結果:
struct timezone{
int tz_minuteswest;/*格林威治時間往西方的時差*/
int tz_dsttime;/*DST 時間的修正方式*/
}
timezone 參數若不使用則傳入NULL便可。
而結構體timeval的定義爲:
struct timeval{
long int tv_sec; // 秒數
long int tv_usec; // 微秒數
}
它得到的時間精確到微秒(1e-6 s)量級。在一段代碼先後分別使用gettimeofday能夠計算代碼執行時間:
struct timeval tv_begin, tv_end;
gettimeofday(&tv_begin, NULL);
foo();
gettimeofday(&tv_end, NULL);
函數執行成功後返回0,失敗後返回-1,錯誤代碼存於errno中。函數

相關文章
相關標籤/搜索