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

 

本文主要学习三个知识点,第一是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: %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
————————————————
 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值