Linux时间时区详解与常用时间函数

时区差东为正,西为负。在此,把东八区时区差记为 +0800

UTC + (+0800) = 本地(北京)时间

UTC与Unix时间戳

在计算机中看到的UTC时间都是从(1970年01月01日 0:00:00)开始计算秒数的。所看到的UTC时间那就是从1970年这个时间点起到具体时间共有多少秒。这个秒数就是Unix时间戳。

time(取得目前的时间)

函数说明:

#include<time.h>

time_t time(time_t *t);

此函数会返回从公元1970年1月1日的UTC时间从0时0分0秒算起到现在所经过的秒数。如果t 并非空指针的话,此函数也会将返回值存到t指针所指的内存。

返回:成功则返回秒数,失败则返回((time_t)-1)值,错误原因存于errno中。

代码说明:

#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <time.h>int main(int argc, char** argv){int seconds = time(NULL);printf(“%d\n”, seconds);return 0;}

执行结果:

[root@linuxidc_CentOS unixtime]# g++ -g -o unixtime_time unixtime_time.cpp

[root@linuxidc_centos unixtime]# ./unixtime_time

1445008165

gmtime(取得目前时间和日期)

函数说明:

#include<time.h>

struct tm*gmtime(const time_t*timep);

gmtime()将参数timep所指的time_t结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果由结构tm返回。结构tm的定义为:struct tm{ int tm_sec; int tm_min; int tm_hour; int tm_mday; int tm_mon; int tm_year; int tm_wday; int tm_yday; int tm_isdst;};int tm_sec 代表目前秒数,正常范围为0-59,但允许至61秒int tm_min 代表目前分数,范围0-59int tm_hour 从午夜算起的时数,范围为0-23int tm_mday 目前月份的日数,范围01-31int tm_mon 代表目前月份,从一月算起,范围从0-11int tm_year 从1900年算起至今的年数int tm_wday 一星期的日数,从星期一算起,范围为0-6int tm_yday 从今年1月1日算起至今的天数,范围为0-365int tm_isdst 日光节约时间的旗标此函数返回的时间日期未经时区转换,而是UTC时间。

返回:结构tm代表目前UTC 时间

代码说明:

#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <time.h>int main(int argc, char** argv){ const char* wday[] = {“Sun”,”Mon”,”Tue”,”Wed”,”Thu”,”Fri”,”Sat”}; time_t timep; struct tm* p; time(&timep); p = gmtime(&timep); printf(“curday = %d-%d-%d\n”, (1900+p->tm_year), (1+p->tm_mon), p->tm_mday); printf(“curweek = %s, curtime = %d:%d:%d\n”, wday[p->tm_wday], p->tm_hour, p->tm_min, p->tm_sec); return 0;}

结果说明:

[root@linuxidc_centos unixtime]# g++ -g -o unixtime_gmtime unixtime_gmtime.cpp

[root@linuxidc_centos unixtime]# ./unixtime_gmtime

curday = 2015-10-16

curweek = Fri, curtime = 15:12:12

[root@linuxidc_centos unixtime]# date -u

Fri Oct 16 15:12:13 UTC 2015

[root@linuxidc_centos unixtime]# date

Fri Oct 16 23:12:16 CST 2015

[root@linuxidc_centos unixtime]# date -R #这里打印出时区信息,北京为东八区

Fri, 16 Oct 2015 23:12:18 +0800

可以看到gmtime返回的时间日期未经过时区转换,这里和date打印的刚好差8小时(中国时区)。

ctime(将时间和日期以字符串格式表示)

函数说明:

#include<time.h>

char *ctime(const time_t *timep);

ctime()将参数timep所指的time_t结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果以字符串形态返回。若再调用相关的时间日期函数,此字符串可能会被破坏。

代码说明:

#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <time.h>int main(int argc, char** argv){time_t timep;time(&timep);printf(“%s”,ctime(&timep));return 0;}

结果说明:

[root@linuxidc_centos unixtime]# g++ -g -o unixtime_ctime unixtime_ctime.cpp

[root@linuxidc_centos unixtime]# ./unixtime_ctime

Fri Oct 16 23:14:33 2015

[root@linuxidc_centos unixtime]# date

Fri Oct 16 23:14:34 CST 2015

asctime(将时间和日期以字符串格式表示)

函数说明:

#include<time.h>

char * asctime(const struct tm * timeptr);

asctime()将参数timeptr所指的tm结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果以字符串形态返回。若再调用相关的时间日期函数,此字符串可能会被破坏。此函数与ctime不同处在于传入的参数是不同的结构。

代码说明:

#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <time.h>int main(int argc, char** argv){time_t timep;time(&timep);printf(“%s”, asctime(gmtime(&timep)));}

结果说明:[root@linuxidc_centos unixtime]# g++ -g -o unixtime_asctime unixtime_asctime.cpp

[root@linuxidc_centos unixtime]# ./unixtime_asctime

Fri Oct 16 15:15:54 2015

[root@linuxidc_centos unixtime]# date

Fri Oct 16 23:15:55 CST 2015

[root@linuxidc_centos unixtime]# date -u

Fri Oct 16 15:15:57 UTC 2015

[root@linuxidc_centos unixtime]# date -R

Fri, 16 Oct 2015 23:16:01 +0800

注意这里struct tm结构的时间是通过gmtime返回的,因此也没有经过时区转换。

gettimeofday(取得目前的时间)

函数说明:

#include <sys/time.h>#include <unistd.h>

int gettimeofday ( struct timeval * tv , struct timezone * tz )

不要等待机会,而要创造机会。

Linux时间时区详解与常用时间函数

相关文章:

你感兴趣的文章:

标签云: