Linux下用C获取当前时间

 更新时间:2017年01月24日 09:17:42   作者:Boblim  
本篇文章主要介绍了Linux获取当前时间的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

Linux下用C获取当前时间,具体如下:

代码(可以把clock_gettime换成time(NULL))

void getNowTime()
{
 timespec time;
 clock_gettime(CLOCK_REALTIME, &time); //获取相对于1970到现在的秒数
 tm nowTime;
 localtime_r(&time.tv_sec, &nowtime);
 char current[1024];
 sprintf(current, "%04d%02d%02d%02d:%02d:%02d", nowTime.tm_year + 1900, nowTime.tm_mon, nowTime.tm_mday, 
  nowTime.tm_hour, nowTime.tm_min, nowTime.tm_sec);
}

分析:

clock_gettime()

 函数"clock_gettime"是基于Linux C语言的时间函数,他可以用于计算精度和纳秒。

语法:

#include<time.h>

int clock_gettime(clockid_t clk_id,struct timespec *tp);

参数:

clk_id : 检索和设置的clk_id指定的时钟时间。

CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,中间时刻如果系统时间被用户改成其他,则对应的时间相应改变

  •   CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响
  •   CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间
  •   CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间
struct timespec

{

time_t tv_sec; /* 秒*/

long tv_nsec; /* 纳秒*/

};

localtime()

localtime是 把从1970-1-1零点零分到当前时间系统所偏移的秒数时间转换为本地时间.

语法

说明:此函数获得的tm结构体的时间是日历时间。

用 法: struct tm *localtime(const time_t *clock);

返回值:返回指向tm 结构体的指针.tm结构体是time.h中定义的用于分别存储时间的各个量(年月日等)的结构体.

例1:

#include <stdio.h>
#include <stddef.h>
#include <time.h>
int main(void)
{
 time_t timer;//time_t就是long int 类型
 struct tm *tblock;
 timer = time(NULL);
 tblock = localtime(&timer);
 printf("Local time is: %s\n", asctime(tblock));
 return 0;
}

执行结果:

Local time is: Mon Feb 16 11:29:26 2009

例2:

上面的例子用了asctime函数,下面这个例子不使用这个函数一样能获取系统当前时间。需要注意的是年份加上1900,月份加上1。

#include<time.h>
#include<stdio.h>
int main()
{
 struct tm *t;
 time_t tt;
 time(&tt);
 t = localtime(&tt);
 printf("%4d年%02d月%02d日 %02d:%02d:%02d\n", t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec);
 return 0;
}

localtime()与localtime_r()的区别

localtime():

#include <cstdlib> 
#include <iostream> 
#include <time.h> 
#include <stdio.h> 
 
using namespace std; 
 
int main(int argc, char *argv[]) 
{ 
 time_t tNow =time(NULL); 
 time_t tEnd = tNow + 1800; 
 //注意下面两行的区别 
 struct tm* ptm = localtime(&tNow); 
 struct tm* ptmEnd = localtime(&tEnd); 
 
 char szTmp[50] = {0}; 
 strftime(szTmp,50,"%H:%M:%S",ptm); 
 char szEnd[50] = {0}; 
 strftime(szEnd,50,"%H:%M:%S",ptmEnd); 
  
 
 printf("%s /n",szTmp); 
 printf("%s /n",szEnd); 
  
 
 system("PAUSE"); 
 return EXIT_SUCCESS; 
}

最后出来的结果是:

21:18:39

21:18:39

和最初想法不一致。

查阅localtime的文档,发现这段话:

This structure is statically allocated and shared by the functions gmtime and localtime. Each time either one of these functions is called the content of this structure is overwritten.

也就是说每次只能同时使用localtime()函数一次,要不就会被重写!

The localtime() function need not be reentrant. A function that is not required to be reentrant is not required to be thread-safe.

因此localtime()不是可重入的。同时libc里提供了一个可重入版的函数localtime_r();

Unlike localtime(), the reentrant version is not required to set tzname。

修改程序:(localtime_r())

#include <cstdlib> 
#include <iostream> 
#include <time.h> 
#include <stdio.h> 
 
using namespace std; 
 
int main(int argc, char *argv[]) 
{ 
 time_t tNow =time(NULL); 
 time_t tEnd = tNow + 1800; 
 
 //在这里修改程序 
 //struct tm* ptm = localtime(&tNow); 
 //struct tm* ptmEnd = localtime(&tEnd); 
 struct tm ptm = { 0 }; 
 struct tm ptmEnd = { 0 }; 
 localtime_r(&tNow, &ptm); 
 localtime_r(&tEnd, &ptmEnd); 
  
 char szTmp[50] = {0}; 
 strftime(szTmp,50,"%H:%M:%S",&ptm); 
 char szEnd[50] = {0}; 
 strftime(szEnd,50,"%H:%M:%S",&ptmEnd); 
 printf("%s /n",szTmp); 
 printf("%s /n",szEnd); 
  
 
 system("PAUSE"); 
 return EXIT_SUCCESS; 
}

最后出来的结果是:

10:29:06
10:59:06

tm

 struct tm {
     int tm_sec;  /* 秒 – 取值区间为[0,59] */ 
     int tm_min;  /* 分 - 取值区间为[0,59] */ 
     int tm_hour;  /* 时 - 取值区间为[0,23] */ 
     int tm_mday;  /* 一个月中的日期 - 取值区间为[1,31] */ 
     int tm_mon;  /* 月份(从一月开始,0代表一月) - 取值区间为[0,11] */ 
     int tm_year;  /* 年份,其值等于实际年份减去1900 */ 
     int tm_wday; /* 星期 – 取值区间为[0,6],其中0代表星期天,1代表星期一 */ 
     int tm_yday; /* 从每年1月1日开始的天数– 取值区间[0,365],其中0代表1月1日 */ 
     int tm_isdst; /* 夏令时标识符,夏令时tm_isdst为正;不实行夏令时tm_isdst为0 */ 
   };

time 函数

返回:1970-1-1, 00:00:00以来经过的秒数

原型: time_t time(time_t *calptr) 

结果可以通过返回值,也可以通过参数得到,见实例

头文件 <time.h>

返回值: 

成功:秒数,从1970-1-1,00:00:00 可以当成整型输出或用于其它函数

失败:-1

例:

 time_t now;
 time(&now);// 等同于now = time(NULL)
 printf("now time is %d\n", now);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Linux模拟网络丢包与延迟的方法

    Linux模拟网络丢包与延迟的方法

    这篇文章主要给大家介绍了关于Linux模拟网络丢包与延迟的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Linux具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • linux防火墙如何查看状态firewall

    linux防火墙如何查看状态firewall

    这篇文章主要介绍了linux防火墙如何查看状态firewall问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • 火山互联linux VPS配置方法

    火山互联linux VPS配置方法

    火山互联推出的免费VPS...拿来学习下还是不错的.申请过几次Liunx系统的.由于不是很熟悉.几次都没能配置好.下面介绍一下.前几天又申请了一个.
    2009-12-12
  • linux下安装配置svn独立服务器的步骤分享

    linux下安装配置svn独立服务器的步骤分享

    subversion(以下简称svn)是近年来崛起的版本管理工具,是cvs的接班人。 svn服务器有2种运行方式:独立服务器和借助apache。2种方式各有利弊
    2011-05-05
  • Ubuntu系统查看进程被kill的命令和方法

    Ubuntu系统查看进程被kill的命令和方法

    这篇文章主要介绍了Ubuntu查看进程被kill的几种方式,在Ubuntu系统中,要查看进程被杀掉的记录,可以使用文中命令和方法,文章通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-05-05
  • Linux和window环境下开放防火墙端口的操作

    Linux和window环境下开放防火墙端口的操作

    开发时会遇到在服务器上部署mysql或者es数据库的情况,此时如果访问数据库就需要开放防火墙端口,本文会讲解windows和linux环境下端口的开放,文章通过图文结合的方式讲解的非常详细,需要的朋友可以参考下
    2024-09-09
  • Centos7.5配置java环境安装tomcat的讲解

    Centos7.5配置java环境安装tomcat的讲解

    今天小编就为大家分享一篇关于Centos7.5配置java环境安装tomcat的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • Linux磁盘空间释放问题整理

    Linux磁盘空间释放问题整理

    在本篇文章里小编给大家分享了一篇关于Linux磁盘空间释放问题整理内容,有需要的朋友们可以学习参考下。
    2020-12-12
  • Linux部署jar包过程

    Linux部署jar包过程

    文章介绍了在Linux系统上部署Java(jar)包时需要注意的几个关键点,包括统一JDK版本、添加打包插件、修改数据库密码以及正确执行jar包的方法
    2025-02-02
  • apache rewrite规则实现白名单

    apache rewrite规则实现白名单

    今天弄了半天apache 的rewrite 规则,还是没有配置出符合的规则。后一同事,研究了半个小时弄出来,很是惭愧。
    2014-06-06

最新评论