概念
UTC和GMT
Coordinated Universal Time(UTC):协调世界时,又称为世界标准时间,也就是大家所熟知的格林威治标准时间(Greenwich Mean Time,GMT)。比如,中国内地的时间与UTC的时差为+8,也就是UTC+8。美国是UTC-5。
Calendar
Calendar Time:日历时间,是用“从一个标准时间点到此时的时间经过的秒数”来表示的时间。这个标准时间点对不同的编译器来说会有所不同,但对一个编译系统来说,这个标准时间点是不变的,该编译系统中的时间对应的日历时间都通过该标准时间点来衡量,所以可以说日历时间是“相对时间”,但是无论你在哪一个时区,在同一时刻对同一个标准时间点来说,日历时间都是一样的。
Epoch
据基准起始时间1970年1月1日 UTC(世界标准时间) 0点的秒数
clock tick
clock tick:时钟计时单元(而不把它叫做时钟滴答次数),一个clock tick不是CPU的一个时钟周期,而是C/C++的一个基本计时单位。
Second family
millisecond 毫秒 ms 1e-3秒
microsecond 微秒 μs 1e-6秒
nanosecond 纳秒 ns 1e-9秒
picosecond 皮秒 ps 1e-12秒
常用C类型
__time_t和__suseconds_t
我们可以使用ANSI标准库中的time.h头文件,。这个头文件中定义的时间和日期所使用的方法,无论是在结构定义,还是命名,都具有明显的C语言风格。下面,我将说明在C/C++中怎样使用日期的时间功能。估计是因为GCC采用C++代码实现C,所以现在跟踪下来的类型定义居然是__STD_TYPE前缀。
__STD_TYPE __TIME_T_TYPE __time_t; /* Seconds since the Epoch. */
而__TIME_T_TYPE宏定义如下:
#define __TIME_T_TYPE __SLONGWORD_TYPE
__SLONGWORD_TYPE宏定义如下:
#define __SLONGWORD_TYPE long int
同样,__suseconds_t类型也是long int.在Linux 64bit和GCC4.6.1环境下,long int是64位的。对__time_t数据类型的值来说,它所表示的时间不能晚于3001年1月1日0时0分0秒。
timeval结构
使用timeval结构需要添加宏#define __need_timeval 1和<time.h>文件一起使用或者引入<sys/time.h>文件。
基准计算时间为1970年1月1日 UTC(世界标准时间) 0点(Epoch)
用time_t表示的时间(日历时间)是从一个时间点(例如:1970年1月1日0时0分0秒)到此时的秒数。在time.h中,我们也可以看到time_t是一个长整型数:
下面的代码演示了如何获取当前系统时间并转换成字符串:
timeval tv;
gettimeofday(&tv,NULL);
std::cout<<ctime(&tv.tv_sec)<<endl;//将秒数转换成当前时间的字符串表示
tm结构
tm数据结构保存了日期和时间的各个字段
相关C函数
time_t相关
time_t代表的秒数转换成时间的字符串表示
ctime函数可以将秒数转换成当前系统时间的字符串表示,格式形如:"Day Mon dd hh:mm:ss yyyy\n"。例子参考下面的timeval一节。
time_t转换成tm
localtime的声明如下:
struct tm *localtime (__const time_t *__timer)
tm到time_t的转换
time_t mktime(struct tm * timeptr)
计算间隔
好像自己直接减法就可以了,不知道为什么需要这个函数。
double difftime(time_t time1, time_t time0);
tm相关
获取当前时间
timeval相关
下面的代码演示了如何获取当前系统时间并转换成字符串:
gettimeofday
获取当前时间,保存在timeval结构中。
第二个参数是时区,已经废弃不用,只需要简单的传递NULL即可。