c语言 获取当前日期和时间的方法
头文件 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;
}
相关文章
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 修复 Data Is Truncated for a Column 错误
发布时间:2023/05/09 浏览次数:72 分类:MySQL
-
本文介绍 MySQL 错误 Data is truncated for a column 的可能原因和解决方法。修复数据因 MySQL 中的列错误而被截断
MySQL 错误 Error Server PID File Could Not Be Found 解决
发布时间:2023/05/09 浏览次数:98 分类:MySQL
-
在这篇文章中,我们将研究错误! Error Server PID File Could Not Be Found! 在 MySQL 及其解决方案中有充分的解释。
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 关键字定义了一种叫做枚举的特殊类型。