时区差东为正,西为负。在此,把东八区时区差记为 +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 )
不要等待机会,而要创造机会。