Linux下用C获取当前时间

linux时间 2024-01-17

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

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

?
12345678910void 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语言的时间函数,他可以用于计算精度和纳秒。

语法:

?
123#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花费的时间
?
123456789struct 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:

?
123456789101112#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。

?
1234567891011#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():

?
12345678910111213141516171819202122232425262728#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())

?
12345678910111213141516171819202122232425262728293031#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

?
1234567891011struct 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

例:

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

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

云锁“服务器漏洞修复”功能使用说明

系统漏洞是指应用软件或操作系统软件在逻辑设计上的缺陷或在编写时产生的错误,这个缺陷或错误可以被不法者或者电脑黑客利用,通过植入木马、病毒等方式来攻击或控制整个电脑,从而窃取您电脑中的重要资料和信息,甚至破坏您的系统。“服务器漏洞修复”可以扫描服务器系统,列出未...
服务器安全云锁服务器漏洞修复

Windows服务器系统怎么做ARP防护

在IDC局域网里边,受到ARP攻击偶尔会出现,在工作中我也碰到过一两次,在服务器上面做好ARP防护对自己的服务器业务而言真的十分重要,下面小编与大家分享一下如何在Windows服务器系统里边做好ARP防护。Windows服务器系统怎么做ARP防护在Window...
服务器安全Windows服务器ARP防护

被DDoS攻击怎么办?这三招帮你防止、减轻DDoS攻击

不少企业都遭遇过黑客的DDoS攻击来,导致资源被耗尽,服务、应用程序或网站崩溃,相信企业都对之深恶痛绝。今天给大家介绍一些有效的防止DDoS攻击的技术和方法,虽然很难完全阻止DDoS攻击的发生,但也能在一定程度上帮助抵御DDoS攻击,并减轻其造成的危害。首先,...
服务器安全网络安全DDos攻击DDos黑客

分享十个便宜VPS主机-VPS服务器建站和搭建应用服务体验

前几天分享了新手建站十大免费空间,看那篇文章的朋友基本上都是从免费空间中走出来了,十个免费空间至少有七、八个是曾经用过的。但是自从花钱购买了付费的虚拟主机和vps主机后,就再也怎么不关心免费空间了,除非是偶尔想用qq到“外”面透透气。从目前的主机和vps价格来...
VPS服务器VPS主机虚拟主机