C语言时间函数之mktime和difftime详解

 更新时间:2022年02月18日 16:25:42   作者:嵌入式@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函数返回的秒数打印出来。

image.png

通过结果可以看到两个函数的秒数相差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函数来计算函数运行的时长。

image.png

通过打印的结果可看出,延时函数的执行时间为2s,程序中的延时也是2s,说明函数计算的结果是正确的。在这里要注意一点difftime函数的返回值是double类型的数据。

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容! 

相关文章

  • C语言从零探索函数的知识

    C语言从零探索函数的知识

    函数是一组一起执行一个任务的语句。每个 C 程序都至少有一个函数,即主函数 main() ,所有简单的程序都可以定义其他额外的函数,让我们一起来了解它
    2022-04-04
  • 详解C语言中的函数、数组与指针

    详解C语言中的函数、数组与指针

    这篇文章主要介绍了C语言中的函数、数组与指针,本文给大家介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • C++中按引用传递参数的好处有哪些

    C++中按引用传递参数的好处有哪些

    这篇文章主要介绍了C++中按引用传递参数的好处有哪些,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • C++编程析构函数拷贝构造函数使用示例详解

    C++编程析构函数拷贝构造函数使用示例详解

    这篇文章主要为大家介绍了C++编程构造函数中析构函数及拷贝构造函数的使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2021-11-11
  • C语言八大排序之堆排序

    C语言八大排序之堆排序

    堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复杂度均为O(nlogn),它也是不稳定排序
    2022-02-02
  • C++中template方法undefined reference to的问题解决

    C++中template方法undefined reference to的问题解决

    Undefined reference to 错误:这类错误是在连接过程中出现的,本文就来介绍一下C++中template方法undefined reference to的问题解决,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • 浅谈C++ Explicit Constructors(显式构造函数)

    浅谈C++ Explicit Constructors(显式构造函数)

    下面小编就为大家带来一篇浅谈C++ Explicit Constructors(显式构造函数)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • 详解Dev C++使用教程(使用Dev C++编写C语言程序)

    详解Dev C++使用教程(使用Dev C++编写C语言程序)

    这篇文章主要介绍了详解Dev C++使用教程(使用Dev C++编写C语言程序),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • C++中使用FFmpeg适配自定义编码器的实现方法

    C++中使用FFmpeg适配自定义编码器的实现方法

    本文介绍了在C++中使用FFmpeg库进行自定义编码器适配的实现方法。文章通过具体的代码示例,介绍了FFmpeg的基本使用方法和自定义编码器的实现过程,帮助读者了解如何在C++中进行音视频编码和解码的开发工作,并能够实现自定义的编码器适配
    2023-04-04
  • C语言零基础彻底掌握预处理下篇

    C语言零基础彻底掌握预处理下篇

    在C语言的程序中包括各种以符号#开头的编译指令,这些指令称为预处理命令。预处理命令属于C语言编译器,而不是C语言的组成部分,通过预处理命令可扩展C语言程序设计的环境
    2022-08-08

最新评论