时间日期与时间戳转换(Linux C)
2018-01-10 11:40
141 查看
本文主要学习三个知识点,第一是UTC时间、GMT时间的概念;第二是在Unix环境下UTC时间与时间戳的转换;第三是在C语言中如何修改时区。
本文参考了《UNP》以及
http://blog.csdn.net/foxir/article/details/43916601
http://blog.csdn.net/ljafl9988/article/details/16847935
UTC,即协调世界时。UTC是以原子时秒长为基础,在时刻上尽量接近于GMT的一种时间计量系统。为确保UTC与GMT相差不会超过0.9秒,在有需要的情况下会在UTC内加上正或负闰秒。UTC现在作为世界标准时间使用。
所以,UTC与GMT基本上等同,误差不超过0.9秒。
若中国当前时间为8点整,则英国时间为0点整。
结果:
1970-01-01 00:00:00
结果:
0
这里并没有把时间设置为1970年1月1日0点,因为这里涉及到时区的问题。我们目前处于东八区,计算时需要减去8小时。
在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)才能得到标准时间。
代码:
当时区设置为东8区时,我们标准时间为8-8=0小时,转换为秒数为:0
当时区设置为国际标准时,标准时间即为8-0=8小时,转换为秒数为:(8-0)*3600=28800
本文参考了《UNP》以及
http://blog.csdn.net/foxir/article/details/43916601
http://blog.csdn.net/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
相关文章推荐
- Linux下如果时间戳转换日期需要比较则采用的函数
- linux下 date命令实现 日期与时间戳互相转换
- linux下date命令实现时间戳与日期的转换
- Mysql日期时间类型(DATE,DATETIME,TIMESTAMP)和函数及与linux系统时间之间的转换(UNIX_TIMESTAMP、FROM_UNIXTIME)
- JavaScript中linux时间戳与日期的转换
- localtime()函数:获取当前时间和日期并转换为本地时间
- UNIX时间戳/日期转换
- js中时间日期转换
- Linux命令之date - 显示、修改系统日期时间
- Python将日期时间按照格式转换成字符串
- 取ORACLE系统时间并转换为日期格式
- SQL Server日期时间格式转换字符串详解
- 前端(js/jquery) 日期和时间戳的转换
- javascript时间戳和日期字符串相互转换
- php日期转时间戳,指定日期转换成时间戳
- Android日期和时间获取和转换
- Python时间,日期,时间戳之间转换
- 时间日期格式的转换
- Linux 指令篇:日期时间排程--sleep