C语言 Unix 时间戳 和 时间日期相互转换

news2024/9/25 23:12:35

Unix 时间戳(也称为 POSIX 时间戳)是一个表示从 1970 年 1 月 1 日 UTC 时刻开始所经过的秒数的数值。这个时间戳是与时间区域无关的,也就是说它在全球任何地方都表示同一个时刻。

如果你要将 Unix 时间戳转换为某个特定时区的时间,你需要考虑该时区相对于 UTC 的偏移量。对于东八区(即 UTC+8),你确实需要在 Unix 时间戳的基础上加上 8 小时的秒数来得到当地的时间。

一般来说,对于不同的时区,处理方法如下:

UTC+X (东部时区):在 Unix 时间戳基础上加 X 小时。
UTC-X (西部时区):在 Unix 时间戳基础上减 X 小时。
例如:
如果你想得到 UTC+3(如莫斯科)的时间,你需要在 Unix 时间戳基础上加上 3 小时。
如果你想得到 UTC-5(如美国东部标准时间 EST)的时间,你需要在 Unix 时间戳基础上减去 5 小时。

1.时间日期转成时间戳

在 C 语言中,<time.h> 头文件提供了日期和时间处理的功能

注意:
Unix 时间戳是从 1970 年 1 月 1 日 00:00:00 UTC 开始计算的,而不是从 1900 年开始。
在 C 语言中,struct tm 结构体用于存储分解后的日期和时间信息。tm_year 成员表示从 1900 年开始的年数,这是因为 struct tm 结构体的设计是为了与早期的日期和时间处理标准兼容,而不是直接与 Unix 时间戳相关联。

struct tm 结构体成员
struct tm 的成员包括但不限于:

  • tm_sec:秒 (0-60)
  • tm_min:分钟 (0-59)
  • tm_hour:小时 (0-23)
  • tm_mday:一个月中的哪一天 (1-31)
  • tm_mon:月份 (0-11),0 表示一月
  • tm_year:从 1900 年开始的年数
  • tm_wday:一周中的哪一天 (0-6),0 表示周日
  • tm_yday:一年中的哪一天 (0-365)
  • tm_isdst:夏令时标志 (-1 表示未知,0 表示不适用,1 表示适用)

在线运行C语言工具

#include <stdlib.h>
#include <time.h>
 
int main()
{
    struct tm my_time = {0};
    time_t timestamp;

    // 设置时间
    my_time.tm_year = 2024 - 1900; // 注意:tm_year 是从 1900 年开始计算的
    my_time.tm_mon = 8 - 1;         // 注意:tm_mon 是从 0 开始的
    my_time.tm_mday = 6;
    my_time.tm_hour = 19;
    my_time.tm_min = 20;
    my_time.tm_sec = 20;

    // 调用 mktime 函数
    timestamp = mktime(&my_time);

    // 检查 mktime 是否成功
    if (timestamp == -1) {
        perror("mktime failed");
        return 1;
    }

    // 打印时间戳
    printf("Timestamp: %ld\n", (long)timestamp);

    return 0;
}

输出结果:Timestamp: 1722972020

换算结果是正确的
unix时间戳在线转换工具
在这里插入图片描述

2.时间戳转成时间日期(方法1)

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

int main()
{
    time_t timestamp;
    struct tm *timeinfo;
    char buffer[20];

    // 假设这是你的时间戳
    timestamp = 1691365220; // 2023-08-06 23:40:20

    // 使用 localtime 函数
    timeinfo = localtime(&timestamp);

    // 使用 strftime 格式化日期和时间
    strftime(buffer, sizeof(buffer), "%Y-%m-%d %H:%M:%S", timeinfo);

    // 打印日期和时间
    printf("Local Date and Time: %s\n", buffer);

    return 0;
}

Local Date and Time: 2023-08-06 23:40:20

3.时间戳转成时间日期(方法2)

asctime 函数会将 struct tm 结构体转换为一个包含完整日期和时间的字符串,并以 "\n" 结尾。

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

int main()
{
    time_t timestamp;
    struct tm *timeinfo;

    // 假设这是你的时间戳
    timestamp = 1722972020; // 2024-08-06 19:20:20

    // 使用 gmtime 函数
    timeinfo = gmtime(&timestamp);

    // 打印日期和时间
    printf("UTC Date and Time: %s", asctime(timeinfo));

    return 0;
}

UTC Date and Time: Tue Aug 6 19:20:20 2024

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1988982.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

封闭式蓝牙耳机推荐?4款更实用的开放式耳机推荐

封闭式耳机我想应该是头戴式耳机中的一种耳机类型吧&#xff0c;而开放式耳机则是一种范围比较大的耳机类型&#xff0c;这两种耳机类型确实有比较大的区别&#xff1a; 声音泄漏与隔音效果&#xff1a; 开放式耳机&#xff1a;由于其设计允许空气流通&#xff0c;因此声音会…

调用DXGI截图初始化失败,提示0xf 887a0004

&#x1f3c6;本文收录于《CSDN问答解惑-专业版》专栏&#xff0c;主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&收…

09.FreeRTOS时间片调度与任务相关函数

文章目录 09. FreeRTOS时间片调度与任务相关函数1. FreeRTOS时间片调度2. 任务状态查询API函数3. 任务时间统计API函数 09. FreeRTOS时间片调度与任务相关函数 1. FreeRTOS时间片调度 时间片调度简介&#xff1a; 时间片调度实验流程&#xff1a; 核心代码&#xff1a; 开…

盲盒卡牌风靡市场,抽卡机小程序成为新的机遇

如今&#xff0c;在商场中都可以看到卡牌的身影&#xff0c;拆卡成为了当下年轻人休闲娱乐的新宠&#xff0c;卡牌市场逐渐升温。抽卡机小程序作为一个能够快速拆卡的新模式&#xff0c;已经逐渐成为了用户拆卡的重要渠道&#xff0c;也为卡牌市场的发展提供了重要方式。本文将…

数字化转型如何通过数据改变企业的运营流程?

不仅仅是技术层面的革新&#xff0c;更是企业运营理念、组织架构、文化氛围及市场策略的全面升级。数字化转型通过深度融合云计算、大数据、人工智能、物联网等前沿技术&#xff0c;优化企业运营流程&#xff0c;提升效率&#xff0c;增强竞争力&#xff0c;从而在快速变化的市…

RTOS(8)信号量和互斥量

1.信号量 信号量分为二值信号量和计数信号量 与队列相比&#xff1a;他不能传输数据&#xff0c;但同时他不需要传输数据&#xff0c;占用的空间也更小&#xff0c;运行更快&#xff1b; 2.互斥量 与二值信号量类似&#xff0c;是特殊的信号量&#xff0c;本身是想实现谁上锁…

【Harmony Next】在鸿蒙项目中一键添加卡片

【Harmony Next】在鸿蒙项目中一键添加卡片 1.下载鸿蒙编译器DevEco Studio的插件DevEco CodeGenie【下载链接】 在华为的编译器现在官网下面可以下载DevEco CodeGenie的压缩包&#xff0c;安装后可以使用DevEco CodeGenie进行智能问答、生成卡片、知识查询等操作 2.安装DevE…

MapStruct实体映射工具

一丶MapStruct是什么 MapStruct 是一个代码生成器,它基于配置方法的约定,极大地简化了 Java Bean 类型之间映射的实现,生成的映射代码使用普通方法调用,因此快速、类型安全且易于理解。 官方网站 MapStruct – Java bean mappings, the easy way! 二丶为什么需要MapStru…

桌管系统能否查微信聊天记录?这篇文章告诉你答案

桌面管理系统&#xff08;简称“桌管系统”&#xff09;确实可以用来监控和查看员工的微信聊天记录。以“安企神”这款桌管系统为例&#xff0c;它提供了全面的功能来帮助企业管理和监控员工的上网行为及通信记录。以下是关于安企神系统如何查看微信聊天记录的一些具体信息&…

什么是行为监控?企业透明化管理新纪元!揭秘四款顶尖行为监控软件!

行为监控&#xff0c;是指通过技术手段对员工在工作场所内的行为、活动以及数据使用情况进行全面、实时的监测与分析。它不仅帮助管理者洞悉员工工作状态&#xff0c;提升团队效率&#xff0c;还能有效防止数据泄露和不当行为&#xff0c;为企业构建更加安全、有序的工作环境。…

RAG前沿技术/解决方案梳理

RAG前沿技术/解决方案梳理 BenchmarkRetrievalAdaptive-RAGDR-RAGRichRAGGenRT Critique/ReasoningSelf-RAGCorrective RAGSpeculative RAGPlanRAGSelf-ReasoningReSP MemorySelfmemHippoRAG Query RewriteRaFe SummaryRefiner 个人理解 对当前RAG的学术研究&#xff08;或者好…

加密的PDF文件怎么能够转换为word文档

Word是一种常见的文档格式&#xff0c;被广泛应用于办公室、教育等领域&#xff0c;目前它拥有较为丰富的文档编辑和格式化功能。然而&#xff0c;因为当前很多场景下&#xff0c;大多数资料文件都是以PDF格式存在&#xff0c;因为其具备比较强的稳定性&#xff0c;所以想要去修…

LearnOpenGL-光照章节学习笔记

LearnOpenGL-光照章节学习笔记 颜色创建一个光照场景 基础光照一、环境光照二、漫反射光照三、镜面反射 材质光照贴图一、漫反射贴图二、镜面光贴图三、放射光贴图 投光物一、平行光二、点光源衰减实现 三、聚光灯平滑边缘 多光源一、平行光&#xff08;定向光&#xff09;二、…

知识分享 | 详解整车区域控制器(ZCU)

随着智能网联汽车技术的迅猛发展&#xff0c;整车区域控制器ZCU&#xff08;Zone Control Unit&#xff09;作为汽车电子电气架构中的核心组件&#xff0c;其重要性日益凸显。ZCU不仅作为区域数据中心、IO中心及配电中心&#xff0c;在车辆动力、传感器管理、信息娱乐等方面发挥…

线性DP+摆渡车

线性DP&#xff1a; 具有线性“阶段”划分的动态规划算法称为线性DP。 线性DP无论状态表示是一维还是多维&#xff0c;DP算法在线性DP问题上都体现出了“作用在线性空间上的阶段划分和状态转移” &#xff0c;DP的阶段沿着各个维度线性增长。从一个或多个“初始状态”开始有方…

uni-app下Worker的使用

1、在static目录下创建一个目录用于存放worker文件 为啥要在static目录下创建worker目录呢&#xff1f;那是因为worker.js没办法在别的js中被引用&#xff0c;uni-app项目编译成微信小程序代码时会进行Tree-shaking&#xff08;摇树优化&#xff09;&#xff0c;把那些没被引用…

全方位教程:接入视频美颜SDK与直播美颜插件的完整步骤

今天&#xff0c;小编将为您详细介绍如何接入视频美颜SDK与直播美颜插件的完整步骤。 一、准备工作 开发环境的搭建 在开始集成之前&#xff0c;确保您的开发环境已配置完毕。无论是使用iOS、Android&#xff0c;还是Web开发&#xff0c;您都需要准备好对应的开发工具链&…

人工智能深度学习系列—深入探索KL散度:度量概率分布差异的关键工具

人工智能深度学习系列—深度解析&#xff1a;交叉熵损失&#xff08;Cross-Entropy Loss&#xff09;在分类问题中的应用 人工智能深度学习系列—深入解析&#xff1a;均方误差损失&#xff08;MSE Loss&#xff09;在深度学习中的应用与实践 人工智能深度学习系列—深入探索KL…

你的报表工具选对了吗?中国式报表的正确制作方法

1. 中国式报表的困境 在许多企业中&#xff0c;“中国式报表”是一个让人头疼的存在。中国式报表通常格式复杂&#xff0c;包含大量数据和多层次的数据结构。它不仅需要展示大量的统计数据&#xff0c;还要通过交叉计算等方式呈现数据之间的关系。这种报表对数据处理能力、展示…

关于hive与hadoop初了解

hdfs分布式存数据&#xff0c;MapReduce处理数据。yarn资源管理和任务调度。 hive就是方便处理hadoop数据的 。 hive本事不处理数据&#xff0c;在hive on yarn上是 将sql转换为mapreduce程序&#xff08;不太理解&#xff0c;后续了解吧&#xff09;