c++时间有关的函数

转载总结http://blog.csdn.net/luoweifu/article/details/20288549

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表示星期一。

函数

  1. time_t time(time_t *)
    获取当前系统时间,参数可为NULL
    精确到秒,而且,传入的参数和不传没啥区别啊。
  1. struct tm *gmtime(long *)
    将参数所表示的秒,转化为结构体tm。实际参数可以是time_t。
    注意返回的是指针。
    返回的时间是格林威治时间,也就是0时区的时间。
    不是线程安全的。

  2. struct tm *localtime(const time_t *)
    同上,但是返回的时间是本时区的时间。
    不是线程安全的。
    使用后的返回值需要立即处理,因为下一次的该函数的返回值会覆盖上一次的。也就是说,如果连续两次使用改行数,其返回值是一样的,后一个函数的返回值,所以不是线程安全的

  3. struct tm *gmtime_r(const time_t *timep, struct tm *result)和struct tm localtime_r(const time_t *timep, struct tm *result)
    是线程安全的。
    创建值的tm然后传入。如果创建指针,然后传入,在运行的时候会报错。
    返回值可以无视,因为并不会返回。读取会出错。第二个参数被填充。

  4. time_t mktime(strcut tm * timeptr);
    上述过程的反向转换

  5. 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)
计算时间间隔才长度。精度为秒。

  1. int gettimeofday(struct timeval*tv,struct timezone *tz )
    把目前的时间用tv 结构体返回,当地时区的信息则放到tz所指的结构中,精确到微秒。
    第二个参数可为空。

你可能感兴趣的:(c++时间有关的函数)