C语言时间函数之mktime和difftime详解
作者:嵌入式@hxydj
这篇文章主要为大家详细介绍了C语言时间函数之mktime和difftime,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一,希望能够给你带来帮助
这两个函数原型如下:
__CRT_INLINE time_t __cdecl mktime(struct tm *_Tm); __CRT_INLINE double __cdecl difftime(time_t _Time1,time_t _Time2);
mktime函数
mktime函数会把参数把 timeptr 所指向的结构转换为自 1970 年 1 月 1 日以来持续时间的秒数,如果发生错误时则返回-1。
参数结构体原型如下:
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 到 11 */ int tm_year; /* 自 1900 起的年数 */ int tm_wday; /* 一周中的第几天,范围从 0 到 6 */ int tm_yday; /* 一年中的第几天,范围从 0 到 365 */ int tm_isdst; /* 夏令时 */ };
下面直接通过一段代码来演示。
#include <stdio.h> #include <stdlib.h> #include <time.h> int main(int argc, char** argv) { int ret,time_cnt; struct tm info; info.tm_year = 2022 - 1900; info.tm_mon = 1 - 1; info.tm_mday = 25; info.tm_hour = 11; info.tm_min = 28; info.tm_sec = 50; info.tm_isdst = -1; ret = mktime(&info); time_cnt = time(NULL); if( ret == -1 ) { printf("Error: unable to make time using mktime\n"); } else { printf("%d %d",ret,time_cnt); } return 0; }
首先定义时间结构体,然后给结构体中的变量赋值,将当前时间值赋给变量,然后在通过time函数获取当前时间的秒数,最后将mktime函数转换后的秒数和time函数返回的秒数打印出来。
通过结果可以看到两个函数的秒数相差1,这是由于程序在编译执行的时候延时了一秒,说明mktime函数转换后的秒数和time函数返回的秒数是一样的。
difftime函数
difftime函数有两个时间参数,这个函数的主要作用返回这两个时间就参数的差,也就是这两个时间值相差的秒数。
一般可以通过这个函数来计算某段代码运行的时间。
#include <stdio.h> #include <stdlib.h> #include <time.h> int main(int argc, char** argv) { time_t start_t, end_t; double diff_t; printf("程序启动...\n"); time(&start_t); sleep(2); printf("运行结束!\n"); time(&end_t); diff_t = difftime(end_t, start_t); printf("\n开始时间: %d 结束时间: %d 代码运行时间: %fs\n", start_t,end_t,diff_t); return 0; }
定义两个变量来记录程序运行前的时间值和程序运行后的时间值,然后通过延时函数来模拟程序的运行过程,最后通过difftime函数来计算函数运行的时长。
通过打印的结果可看出,延时函数的执行时间为2s,程序中的延时也是2s,说明函数计算的结果是正确的。在这里要注意一点difftime函数的返回值是double
类型的数据。
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!