unix时间戳定义为从当前到1970.1.1 0时0分0秒,这中间的秒数。使用32位表示的时间戳最多到2038年01月19日03时14分07秒。
linux下存储时间常见的有两种存储方式,一个是从1970年到现在经过了多少秒,一个是用一个结构来分别存储年月日时分秒的。
time_t 这种类型就是用来存储从1970年到现在经过了多少秒,要想更精确一点,可以用结构struct timeval,它精确到微秒。
struct timeval
{
long tv_sec; /*秒*/
long tv_usec; /*微秒*/
};
而直接存储年月日的是一个结构:
struct tm{
int tm_sec; /*秒,正常范围0-59, 但允许至61*/
int tm_min; /*分钟,0-59*/
int tm_hour; /*小时, 0-23*/
int tm_mday; /*日,即一个月**中的**第几天,1-31*/
int tm_mon; /*月, 从一月算起,0-11*/ 1+p->tm_mon;
int tm_year; /*年, 从1900至今已经多少年*/ 1900+ p->tm_year;
int tm_wday; /*星期,一周**中的**第几天, 从星期日算起,0-6*/
int tm_yday; /*从今年1月1日到目前的天数,范围0-365*/
int tm_isdst; /*日光节约时间的旗标*/
};
需要特别注意的是,年份是从1900年起至今多少年,而不是直接存储如2011年,月份从0开始的,0表示一月,星期也是从0开始的, 0表示星期日,1表示星期一。
函数
- time_t time(time_t *)
获取当前系统时间,参数可为NULL
精确到秒,而且,传入的参数和不传没啥区别啊。
struct tm *gmtime(long *)
将参数所表示的秒,转化为结构体tm。实际参数可以是time_t。
注意返回的是指针。
返回的时间是格林威治时间,也就是0时区的时间。
不是线程安全的。struct tm *localtime(const time_t *)
同上,但是返回的时间是本时区的时间。
不是线程安全的。
使用后的返回值需要立即处理,因为下一次的该函数的返回值会覆盖上一次的。也就是说,如果连续两次使用改行数,其返回值是一样的,后一个函数的返回值,所以不是线程安全的struct tm *gmtime_r(const time_t *timep, struct tm *result)和struct tm localtime_r(const time_t *timep, struct tm *result)
是线程安全的。
创建值的tm然后传入。如果创建指针,然后传入,在运行的时候会报错。
返回值可以无视,因为并不会返回。读取会出错。第二个参数被填充。time_t mktime(strcut tm * timeptr);
上述过程的反向转换char *asctime(const struct tm *tblock)和 char *ctime(const time_t *time)
格式化时间,两个函数的区别是,接受的参数不同。
形如:Mon Feb 16 11:29:26 2009
7.size_t strftime(char *strDest,size_t maxsize,const char *format,const struct tm *timeptr)
与上一个相同,但是会格式化为我们指定的格式。
8.double difftime(time_t time1, time_t time0)
计算时间间隔才长度。精度为秒。
- int gettimeofday(struct timeval*tv,struct timezone *tz )
把目前的时间用tv 结构体返回,当地时区的信息则放到tz所指的结构中,精确到微秒。
第二个参数可为空。