300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 时间日期与时间戳转换(Linux C)

时间日期与时间戳转换(Linux C)

时间:2024-01-07 14:43:56

相关推荐

时间日期与时间戳转换(Linux C)

本文主要学习三个知识点,第一是UTC时间、GMT时间的概念;第二是在Unix环境下UTC时间与时间戳的转换;第三是在C语言中如何修改时区。

本文参考了《UNP》以及

/foxir/article/details/43916601

/ljafl9988/article/details/16847935

一、时间与日期

GMT和UTC

GMT,即格林尼治标准时间,也就是世界时。GMT的正午是指当太阳横穿格林尼治子午线(本初子午线)时的时间。但由于地球自转不均匀不规则,导致GMT不精确,现在已经不再作为世界标准时间使用。

UTC,即协调世界时。UTC是以原子时秒长为基础,在时刻上尽量接近于GMT的一种时间计量系统。为确保UTC与GMT相差不会超过0.9秒,在有需要的情况下会在UTC内加上正或负闰秒。UTC现在作为世界标准时间使用。

所以,UTC与GMT基本上等同,误差不超过0.9秒。

时区

地球自西向东旋转,东边比西边先看到太阳,东边的时间也比西边的早。为了统一世界的时间,1884年的国际经度会议规规定将全球划分为24个时区(东、西各12个时区)。规定英国(格林尼治天文台旧址)为零时区(GMT+00),东1-12区,西1-12区,中国北京处于东8区(GMT+08)。

若中国当前时间为8点整,则英国时间为0点整。

UNIX时间戳

由Unix内核提供的基本时间服务是自国际标准时间公元1970年1月1日00:00:00以来的秒数。

二、时间字符串相互转换

时间戳转换为格式化日期

流程: time_t(日历时间) ——->struct tm(以年月日、时分秒表示的时间)——>格式化字符串(利用strftime函数)

#include <stdio.h> #include <time.h> int main(int argc, const char * argv[]) { time_t t; struct tm *p; t=0; p=gmtime(&t); char s[100]; strftime(s, sizeof(s), "%Y-%m-%d %H:%M:%S", p); printf("%d: %s\n", (int)t, s); return 0; }

结果:

1970-01-01 00:00:00

格式化日期转换为时间戳

流程: struct tm(以年月日、时分秒表示的时间) —> time_t(日历时间)

#include <stdio.h> #include <time.h> #include <stdlib.h> int main(int argc, const char * argv[]) { struct tm* tmp_time = (struct tm*)malloc(sizeof(struct tm)); strptime("19700101080000","%Y%m%d%H%M%S",tmp_time); //时间24时制time_t t = mktime(tmp_time); printf("%ld\n",t); free(tmp_time); return 0; }

结果:

0

这里并没有把时间设置为1970年1月1日0点,因为这里涉及到时区的问题。我们目前处于东八区,计算时需要减去8小时。

三、环境变量TZ及时区设置函数

在UNP书里讲过,时间函数除了gmttime()、asctime()不受环境变量TZ的影响外,大部分函数都受到环境变量TZ的影响,这几个函数是: localtime、mktime、ctime和strftime。如果定义了TZ,则这些函数将使用其值以代替系统默认时区。

在Unix环境下可以通过改变系统文件修改环境变量,也可以通过函数setenv()修改。

TZ指定了当前的系统时区。这个时区会影响我们所做的时间转换。例如假设当前的系统时间是8:00AM,如果我们把当前的时区设置成东八区,则标准时间就是(即GMT+0)的时间就是8-8=0:00AM,如果是看成是东6区的话,则标准时间就变成了8-6=2:00AM。

时区设置函数是: setenv(“TZ”, “GMT+0”, 1);//将当前时区设置成标准区

setenv(“TZ”, “GMT-8”, 1); 表示的意思就是:将当前时区设置成东八区。需要注意的是,这里要写成GMT-8才是东八区,不是GMT+8,原因GMT表示时间的方式有点不同,它的格式是(GMT[+/-]offset), 如果目标时区是在东区,则是负的,否则是正的。意思就是本地时区加减多少(offset)才能得到标准时间。

代码:

#include <stdio.h> #include <time.h> #include <stdlib.h> int main(int argc, const char * argv[]) { setenv("TZ", "GMT-8", 1);//时区设置为东8区//setenv("TZ", "GMT+0", 1);//将当前时区设置成标准区struct tm* tmp_time = (struct tm*)malloc(sizeof(struct tm)); strptime("19700101080000","%Y%m%d%H%M%S",tmp_time); //时间24时制time_t t = mktime(tmp_time); printf("%ld\n",t); free(tmp_time); return 0; }

当时区设置为东8区时,我们标准时间为8-8=0小时,转换为秒数为:0

当时区设置为国际标准时,标准时间即为8-0=8小时,转换为秒数为:(8-0)*3600=28800

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。