time

功能:获取1970年1月1日00:00:00到现在的秒数

原型:time_t time(time_t *t);

参数:

  t:获取到的秒数

返回:获取到的秒数

说明:在time.h中定义了time_t类型就是long类型。通过形参或返回值获取到的值是一样的。

localtime

功能:将1970年1月1日00:00:00到现在的秒数转换为当地日历时间

原型:struct tm *localtime(const time_t *timep);

参数:

  timep:保存秒数的地址

返回:成功返回日历时间结构体指针,失败返回NULL。

struct tm结构为:

   struct tm {
int tm_sec; /* seconds */
int tm_min; /* minutes */
int tm_hour; /* hours */
int tm_mday; /* day of the month */
int tm_mon; /* month */
int tm_year; /* year */
int tm_wday; /* day of the week */
int tm_yday; /* day in the year */
int tm_isdst; /* daylight saving time */
};

需要注意的几个点:

  1)tm_year是从年开始,tm_mon是从0开始。

  2)tm_wday是星期,tm_yday是

  3)tm_isdst是指示夏令时在所述时间是否有效的标志。如果夏令时有效,则该值为正值;如果夏令时无效,则该值为零;如果信息不可用,则该值为负值。

测试程序:

 #include <stdio.h>
#include <time.h> int main(int argc, const char *argv[])
{
time_t sec;
struct tm *p_tm = NULL; time(&sec);
p_tm = localtime(&sec);
if (p_tm == NULL) {
return ;
} printf("%d-%d-%d %d:%d:%d\n",
p_tm->tm_year + ,
p_tm->tm_mon + ,
p_tm->tm_mday,
p_tm->tm_hour,
p_tm->tm_min,
p_tm->tm_sec);
printf("tm_wday = %d\n", p_tm->tm_wday);
printf("tm_yday = %d\n", p_tm->tm_yday);
printf("tm_isdst = %d\n", p_tm->tm_isdst); return ;
}

执行结果:

gmtime

gmtime与localtime非常相似,区别就是localtime得到的是当地时间,而gmtime得到的是0时区的时间。

功能:功能:将1970年1月1日00:00:00到现在的秒数转换为0时区的日历时间

原型:struct tm *gmtime(const time_t *timep);

参数:

  timep:保存秒数的地址

返回:成功返回日历时间,失败返回NULL。

ctime

功能:将时间秒数转化为字符串

原型:char *ctime(const time_t *timep);

参数:

  timep:保存秒数的地址

返回:成功返回获得时间的字符串首地址,失败返回NULL。

测试程序:

 #include <stdio.h>
#include <time.h> int main(int argc, const char *argv[])
{
time_t sec;
char *p_str = NULL; time(&sec);
p_str = ctime(&sec);
if (p_str == NULL) {
return ;
} printf("%s\n", p_str); return ;
}

asctime

功能:将日历时间结构体转换为字符串时间

原型:char *asctime(const struct tm *tm);

参数:

  tm:日历时间地址

返回:成功字符串时间地址,失败返回NULL。

测试程序:

 #include <stdio.h>
#include <time.h> int main(int argc, const char *argv[])
{
time_t sec;
struct tm *p_tm = NULL;
char *p_str = NULL; time(&sec);
p_tm = localtime(&sec);
if (p_tm == NULL) {
return ;
} p_str = asctime(p_tm);
if (p_str == NULL) {
return ;
} printf("%s\n", p_str); return ;
}

mktime

功能:将日历时间转换为1970年1月1日00:00:00到现在的秒数

原型:time_t mktime(struct tm *tm);

参数:

  tm:日历时间

返回:秒数

小结

各种时间的转换关系如下图所示:

最后提一下,有些函数直接返回一个指针,这种方法不常用,觉得这个指针可能是函数内部动态申请得到的,想着最后要不要用free释放,但是用valgrind检查发现并没有内存泄漏,hhh,具体他怎么实现的就不知道了。

gettimeofday

功能:获取当前时间和时区信息

原型:int gettimeofday(struct timeval *tv, struct timezone *tz);

参数:

  tv:时间信息

  tz:时区信息

  若传入某个参数为NULL表明对该项不感兴趣

返回:成功返回0,失败返回-1

timeval 结构如下:

struct timeval {
time_t tv_sec; /* seconds */
suseconds_t tv_usec; /* microseconds */
};

其中tv_sec是1970年1月1日00:00:00到现在的秒数,tv_usec则是微秒数。

timezone 结构如下:

struct timezone {
int tz_minuteswest; /* minutes west of Greenwich */
int tz_dsttime; /* type of DST correction */
};

其中tz_minuteswest指的是与Greenwich时间差了多少分钟,tz_dsttime在linux中不使用。

注意使用该函数需要包含头文件sys/time.h

settimeofday

功能:设置当前时间和时区信息

原型:int settimeofday(const struct timeval *tv, const struct timezone *tz);

参数:

  tv:时间信息

  tz:时区信息

返回:成功执行时,返回0。失败返回-1,errno被设为以下的某个值
  EFAULT:tv或tz其中某一项指向的空间不可访问
  EINVAL:时区格式无效
  EPERM:权限不足,调用进程不允许使用settimeofday设置当前时间和时区值

执行settimeofday函数的进程要有root权限。

linux实时时钟相关函数的更多相关文章

  1. linux 实时时钟(RTC)驱动【转】

    转自:http://blog.csdn.net/yaozhenguo2006/article/details/6820218 这个是linux内核文档关于rtc实时时钟部分的说明,此文档主要描述了rt ...

  2. 【转】VxWorks中高精度实时时钟的实现及C语言汇编混合编程

    最近一个项目中需要在VxWorks下使用一个高精度实时时钟,要求精度为1ms,溢 出时间大于5小时.VxWorks提供系统时钟,该时钟在操作系统启动后开始计数,精度为1个tick,可以通过tickGe ...

  3. 实时时钟、系统时钟和CPU时钟的区别

    http://blog.sina.com.cn/s/blog_68f909c30100pli7.html 实时时钟:RTC时钟,用于提供年.月.日.时.分.秒和星期等的实时时间信息,由后备电池供电,当 ...

  4. Linux的时钟管理

    本文转自博客园zhenwenxian的Linux时间管理,很详细,写得很不错,对初学者还是有很大帮助的. 时间管理在内核中占有非常重要的地位.相对于事件驱动,内核中有大量的函数都是基于时间驱动的.内核 ...

  5. RTC实时时钟驱动

    RTC(Real-Time Clock)实时时钟为操作系统提供了一个可靠的时间,并且在断电的情况下,RTC实时时钟也可以通过电池供电,一直运行下去. RTC通过STRB/LDRB这两个ARM指令向CP ...

  6. STC8H开发(十三): I2C驱动DS3231高精度实时时钟芯片

    目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...

  7. STC8H开发(十四): I2C驱动RX8025T高精度实时时钟芯片

    目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...

  8. ASM:《X86汇编语言-从实模式到保护模式》第9章:实模式下中断机制和实时时钟

    中断是处理器一个非常重要的工作机制.第9章是讲中断在实模式下如何工作,第17章是讲中断在保护模式下如何工作. ★PART1:外部硬件中断 外部硬件中断是通过两个信号线引入处理器内部的,这两条线分别叫N ...

  9. RTC实时时钟

    作者:宋老师,华清远见嵌入式学院讲师. 1.1 RTC介绍 在 一个嵌入式系统中,通常采用RTC 来提供可靠的系统时间,包括时分秒和年月日等,而且要求在系统处于关机状态下它也能够正常工作(通常采用后备 ...

随机推荐

  1. 【转】 glibc detected *** corrupted double-linked list:错误的原因有如下三种可能

    一个多线程的大程序运行的时候崩掉了,屏幕上打出这个:   *** glibc detected *** corrupted double-linked list: 0xb78381d8 *** 三个原 ...

  2. python 学习笔记 3 ----> dive into python 3

    Python内置数据类型 注意: Python可以不需要声明变量的数据类型.它是根据变量的初始赋值情况分析数据类型,并在内部跟踪变量. 比较重要的数据类型: 1 布尔型(Booleans):True. ...

  3. java中,字符串和集合判断是否为空

    字符串: 集合: 不为空

  4. __FILE__、__DIR__区别

    __FILE__=D:\Soft\xampp\htdocs\test\test.php __DIR__=D:\Soft\xampp\htdocs\test getcwd()=D:\Soft\xampp ...

  5. 『超分辨率重建』从SRCNN到WDSR

    超分辨率重建技术(Super-Resolution)是指从观测到的低分辨率图像重建出相应的高分辨率图像.SR可分为两类:    1. 从多张低分辨率图像重建出高分辨率图像    2. 从单张低分辨率图 ...

  6. 字符串sorted,和sort区别

    s=["a","s","b"] s.sort() print(s) ['a', 'b', 's'] s=["a",&qu ...

  7. IIS部署发布flask网站

    先参考http://python.jobbole.com/87655/,会发现失败. 再参考https://blog.csdn.net/david_lee13/article/details/8198 ...

  8. java既然存在gc线程,为什么还存在内存泄漏?

    java既然存在gc线程,为什么还存在内存泄漏? 1.既然 Java 的垃圾回收机制能够自动的回收内存,怎么还会出现内存泄漏的情况呢?这个问题,我们需要知道 GC 在什么时候回收内存对象,什么样的内存 ...

  9. Anaconda与Spyder升级命令

    step1:首先以管理员的身份启动cmd.exe: step2:升级conda(升级Anaconda前需要先升级conda)命令为:conda update conda step3:升级anacond ...

  10. oracle如何调试存储过程

    oracle如果存储过程比较复杂,我们要定位到错误就比较困难,那么可以存储过程的调试功能 先按简单的存储过程做个例子,就是上次做的存储过程(proc_test) 1.先在数据库的procedures文 ...