转载原文地址:c语言中有关时间、日期等的函数详解
总结:
time_t time(time_t *timer);
返回以格林尼治时间(GMT)为标准,从1970年1月1日00:00:00到此刻的本地时间所经过的秒数,time_t实际是个long长整型:typedeflong time_t; time函数只能精确到秒级。
clock_t clock(void);
返回进程启动到调用函数时所经过的CPU时钟计时单元(clocktick)数,在MSDN中称之为挂钟时间(wal-clock),以毫秒为单位,也就是说clock函数可精确到毫秒级,clock_t实际是个long长整型typedeflong clock_t。
---------------------------------------------------------------------分割线---------------------------------------------------------------------------------------------
以下内容来自:c语言Windows及Linux平台下的计时函数总结。
分割线上是关于秒以及毫秒级的定时,如果需要更精确的定时,如微秒级的,可以利用一些平台中特有的函数,如:
Window平台特有函数
DWORD timeGetTime(void);
返回系统时间,以毫秒为单位。系统时间是从系统启动到调用函数时所经过的毫秒数。注意,该值是32位的,会在0到2^32之间循环,约49.71天。
DWORD WINAPI GetTickCount(void);
这个函数和timeGetTime()一样也是返回系统时间,以毫秒为单位。
高精度计时,以微秒为单位(1毫秒=1000微秒)。
BOOL QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount);得到高精度计时器的值(如果存在这样的计时器)。
BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency);返回硬件支持的高精度计数器的频率(次每秒),返回0表示失败。
其中LARGE_INTEGER其实是一个联合体,可以得到__int64 QuadPart;也可以分别得到低32位DWORD LowPart和高32位的值LONG HighPart。
在使用时,先使用QueryPerformanceFrequency()得到计数器的频率,再计算二次调用QueryPerformanceCounter()所得的计时器值之差,
用差去除以频率就得到精确的计时了。
Linux平台特有函数
int gettimeofday(struct timeval *tv,struct timezone *tz);
获得当前精确时间(1970年1月1日到现在的时间),精度为微秒。
保存时间的结构体
strut timeval {
long tv_sec; //秒数
long tv_usec; //微秒数
};