首页 > 编程知识 正文

时间戳转换成日期,时间戳转换日期查询

时间:2023-05-03 05:13:59 阅读:260809 作者:1304

 

本文主要学习三个知识点,第一是UTC时间、GMT时间的概念;第二是在Unix环境下UTC时间与时间戳的转换;第三是在C语言中如何修改时区。 本文参考了《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: %sn", (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("%ldn",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("%ldn",t);      free(tmp_time);      return 0;  }  


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

快三高手技巧nix环境下可以通过改变系统文件修改环境变量,也可以通过函数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("%ldn",t);      free(tmp_time);      return 0;  }  


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

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。