迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 >

c语言 获取当前日期和时间的方法

作者:迹忆客 最近更新:2022/12/26 浏览次数:

头文件 time.h

#include <time.h>

要获取时间,就不得不说一个函数 time()

原型: time_t time(time_t * timer)

php语言中就有time() 这个函数,返回一个时间戳——也就是一个整数。然后再通过 date() 函数进行格式化,转换成我们想要的时间格式。 在C中,该函数的功能是获取当前的系统时间,返回的是一个time_t 类型的值。 也是一个时间戳。其实就是一个大整数。这个整数值是怎么算出来的呢,就是从 UTC(Coordinate Universal Time) 时间1970年1月1日00:00:00(称为UNIX系统的Epoch时间)到当前时刻的秒数。

仅仅有这个秒数还是不够的,还需要一种方式将其转化为我们需要的格式。在C中可以调用localtime()函数将time_t表示的UTC时间转换为本地时间(我们是+8区,比UTC多8个小时)并转成 struct tm类型。

time_t的数字是按UTC算的,跟时区无关,同一个时刻全球所有计算机上的time(NULL)返回值都相同。 用localtime()转换成可显示的格式时才需要考虑时区。

time_t 转化为 struct tm 的函数有两个 —— localtime()gmtime()

原型: struct tm * localtime(time_t *timer)struct tm * gmtime(time_t *timer)

这两个函数的区别是 gmtime() 转换出来的是 0 时区的时间。而 localtime() 是将本地的时区计算在内的。 什么意思呢,就是说我们的时区是+8区,比UTC多8个小时。假设当前时间是 15:40:56。 使用 gmtime() 转出来之后就是 7:40:56; 使用 localtime() 转出来之后就是 15:40:56

下面再来介绍struct tm

struct tm {
    int tm_sec;  // 秒
    int tm_min;  // 分
    int tm_hour; // 时
    int tm_mday; // 日
    int tm_mon;  // 月
    int tm_year; // 年
    int tm_wday; // 表示周几  0-6 (0:周日 1:周一 2:周二  3:周三 4:周四 5:周五 6:周六)
    int tm_yday; // 从 一月一日开始算到现在是一年中的第几天 取值 0-365
    int tm_isdst; // 表示是否是夏令时  1是  0否   在mktime() 函数中使用  有时候为-1,则由mktime() 自己去判断是否是夏令时
};

需要注意的是 tm_mon 是从 0 开始的,也就是说月份要加 1; tm_year 是表示从1900到现在过了多少年,也就是今年和1900年的一个差值。所以要使用 tm_year+1900 才表示今年的年份。

下面是完整的例子

#include <time.h>
#include <stdio.h>

int main(void)
{
    time_t time_ptr;
    struct tm *tmp_ptr = NULL;
    int year,month,day,hour,minute,sec;
    // 获取当前时间
    time(&time_ptr);
    tmp_ptr = localtime(&time_ptr);

    year = tmp_ptr->tm_year + 1900;
    month = tmp_ptr->tm_mon + 1;
    day = tmp_ptr->tm_mday;

    hour = tmp_ptr->tm_hour;
    minute = tmp_ptr->tm_min;
    sec = tmp_ptr->tm_sec;
    
    printf(date_time,"[%d-%d-%d %d:%d:%d] ",year,month,day,hour,minute,sec);
    return 0;
}

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Oracle 的 decode 函数在 MySQL 中的等价物

发布时间:2023/05/09 浏览次数:115 分类:MySQL

本篇文章介绍了三种替代实现,我们可以将它们用作 MySQL 中 Oracle 的 decode() 函数的等价物。 为此,我们将使用 IF()、CASE 以及 FIELD() 和 ELT() 的组合。

更改 MySQL 服务器中的 max_allowed_packet Size

发布时间:2023/05/09 浏览次数:142 分类:MySQL

本篇文章介绍如何更改 MySQL 服务器中的 max_allowed_packet 大小。 为了了解这一点,我们将使用两个操作系统,Windows 10 和 Linux (Ubuntu)。

MySQL ForEach 循环

发布时间:2023/05/08 浏览次数:140 分类:MySQL

本篇文章介绍如何在一条语句中使用 INSERT、SELECT、WHERE 和 JOIN 模拟 MySQL 中的 foreach 循环。

使用 JDBC 连接到 MySQL 数据库

发布时间:2023/05/08 浏览次数:82 分类:MySQL

本文讨论 JDBC 以及使用 JDBC 连接数据库的要求。 我们还查看了一个示例,以了解如何实现 Java 代码来连接 MySQL 数据库。MySQL 为使用 Java 编程语言和 MySQL Connector/J 开发的应用程序提供连接。

遍历 MySQL 表的所有行

发布时间:2023/05/08 浏览次数:161 分类:MySQL

本篇文章介绍了如何使用 WHILE 和 CURSOR 遍历 MySQL 表的所有行。遍历 MySQL 表的所有行

在 C 语言中使用 typedef enum

发布时间:2023/05/07 浏览次数:181 分类:C语言

本文介绍了如何在 C 语言中使用 typedef enum。使用 enum 在 C 语言中定义命名整数常量 enum 关键字定义了一种叫做枚举的特殊类型。

C 语言中的静态变量

发布时间:2023/05/07 浏览次数:151 分类:C语言

本文介绍了如何在 C 语言中使用静态变量。在 C 语言中使用 static 变量在函数调用之间保存变量值

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便