STM32F1之RTC实时时钟(Unix时间戳)

news2025/1/12 16:09:42

目录

1.  Unix时间戳

2.  UTC/GMT

3.  时间戳转换

3.1  time_t

3.2  struct tm

3.3  char *

3.4  时间戳的使用


        实时时钟是一个独立的定时器。RTC模块拥有一组连续计数的计数器,在相应软件配置下,可提供时钟日历的功能。修改计数器的值可以重新设置系统当前的时间和日期。

        RTC模块和时钟配置系统(RCC_BDCR寄存器)处于后备区域,即在系统复位或从待机模式唤醒后,RTC的设置和时间维持不变。

        系统复位后,对后备寄存器和RTC的访问被禁止,这是为了防止对后备区域(BKP)的意外写操作。执行以下操作将使能对后备寄存器和RTC的访问:

● 设置寄存器RCC_APB1ENR的PWREN和BKPEN位,使能电源和后备接口时钟

● 设置寄存器PWR_CR的DBP位,使能对后备寄存器和RTC的访问。

1.  Unix时间戳

        Unix时间戳(Unix Timestamp)定义为从UTC/GMT的1970年1月1日0时0分0秒开始所经过的秒数,不考虑闰秒。

        时间戳存储在一个秒计数器中,秒计数器为32位/64位的整型变量世界上所有时区的秒计数器相同,不同时区通过添加偏移来得到当地时间。

2.  UTC/GMT

        GMT (Greenwich Mean Time)格林尼治标准时间是一种以地球自转为基础的时间计量系统。它将地球自转一周的时间间隔等分为24小时,以此确定计时标准。

        UTC (Universal Time Coordinated)协调世界时是一种以原子钟为基础的时间计量系统。它规定铯133原子基态的两个超精细能级间在零磁场下跃迁辐射9,192,631,770周所持续的时间为1秒。当原子钟计时一天的时间与地球自转一周的时间相差超过0.9秒时, UTC会执行闰秒来保证其计时与地球自转的协调一致。

3.  时间戳转换

        C语言的time.h模块提供了时间获取和时间戳转换的相关函数,可以方便地进行秒计数器、日期时间和字符串之间的转换。

3.1  time_t

        首先,对于time_t的数据我们可以随意打开一款C语言编辑器,打上一段代码。

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

time_t time_cnt;


int main()
{
    

    return 0;
}

        右键time_t进行跳转,可以看到:

#ifndef _TIME64_T_DEFINED
#define _TIME64_T_DEFINED
__MINGW_EXTENSION typedef __int64 __time64_t;
#endif /* _TIME64_T_DEFINED */

#ifndef _TIME_T_DEFINED
#define _TIME_T_DEFINED
#ifdef _USE_32BIT_TIME_T
typedef __time32_t time_t;
#else
typedef __time64_t time_t;
#endif
#endif /* _TIME_T_DEFINED */

        从上述代码可以看出time_t是一个int型的64位数据,所以不用担心溢出问题,用来存储时间戳一直自增的秒数。

3.2  struct tm

        在上述代码中添加关于struct tm的代码,如下:

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

time_t time_cnt;
struct tm time_date;

int main()
{
    

    return 0;
}

        右键头文件time.h跳转到定义,可以看到如下:

#ifndef _TM_DEFINED
#define _TM_DEFINED
  struct tm {
    int tm_sec;
    int tm_min;
    int tm_hour;
    int tm_mday;
    int tm_mon;
    int tm_year;
    int tm_wday;
    int tm_yday;
    int tm_isdst;
  };
#endif

        可以看出他是一个封装的结构体类型,分别代表年月日时分秒等数据,对于tm_isdst来说,+1表示使用夏令时,0表示不使用,-1表示不知道。

3.3  char *

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
    

    return 0;
}

3.4  时间戳的使用

        首先按照如下代码进行编写,可以打印此时自己电脑的当前时间,需要注意的是打印的时间,需要进行转换(网上浏览器直接搜索“时间戳”会出现时间戳转换工具非常的方便,可以验证一下)。

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
    time_cnt=time(NULL);
    
	printf("%d\n",time_cnt);
    return 0;
}

以上代码也可以写作:

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
//    time_cnt=time(NULL);
    time(&time_cnt);
    
	printf("%d\n",time_cnt);
    return 0;
}

效果是一样的。

        下面我们可以手动输入一个数,进行求出手动输入数字所代表的时间,代码如下:

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
//    time_cnt=time(NULL);
//    time(&time_cnt);
	time_cnt=1672588795;   
	printf("%d\n",time_cnt);
	
	time_date=*gmtime(&time_cnt);
	printf("%d\n",time_date.tm_year+1900);//注意,程序里的年是从1900年经过的年数,所以要计算出想要的年份需要+1900年的偏移 
	printf("%d\n",time_date.tm_mon+1);//同理月在程序中从1月开始计算,所以需要加1月的偏移 
	printf("%d\n",time_date.tm_mday);
//	printf("%d\n",time_date.tm_hour);//此时求出的是伦敦时间
	printf("%d\n",time_date.tm_hour+8);//求北京时间需要再+8,我们处于东八区	 
	printf("%d\n",time_date.tm_min);
	printf("%d\n",time_date.tm_sec);
	printf("%d\n",time_date.tm_wday);//0代表星期天 
	
    return 0;
}

        除此之外,我们也可以使用localtime,他可以根据我们电脑所在的时区自动进行时区偏移。

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
//    time_cnt=time(NULL);
//    time(&time_cnt);
	time_cnt=1672588795;   
	printf("%d\n",time_cnt);
	
	time_date=*localtime(&time_cnt);
	printf("%d\n",time_date.tm_year+1900);//注意,程序里的年是从1900年经过的年数,所以要计算出想要的年份需要+1900年的偏移 
	printf("%d\n",time_date.tm_mon+1);//同理月在程序中从1月开始计算,所以需要加1月的偏移 
	printf("%d\n",time_date.tm_mday);
	printf("%d\n",time_date.tm_hour);
	printf("%d\n",time_date.tm_min);
	printf("%d\n",time_date.tm_sec);
	printf("%d\n",time_date.tm_wday);//0代表星期天 
	
    return 0;
}

        下面我们进行上述操作的反向操作,输入一个当前时间进行转换为秒数:

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
//    time_cnt=time(NULL);
//    time(&time_cnt);
	time_cnt=1672588795;   
	printf("%d\n",time_cnt);
	
	time_date=*localtime(&time_cnt);
	printf("%d\n",time_date.tm_year+1900);//注意,程序里的年是从1900年经过的年数,所以要计算出想要的年份需要+1900年的偏移 
	printf("%d\n",time_date.tm_mon+1);//同理月在程序中从1月开始计算,所以需要加1月的偏移 
	printf("%d\n",time_date.tm_mday);
	printf("%d\n",time_date.tm_hour);
	printf("%d\n",time_date.tm_min);
	printf("%d\n",time_date.tm_sec);
	printf("%d\n",time_date.tm_wday);//0代表星期天 
	
	time_cnt=mktime(&time_date);
	printf("%d\n",time_cnt);
	
    return 0;
}

        转换成日期时间:

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

time_t time_cnt;
struct tm time_date;
char *time_str; 

int main()
{
//    time_cnt=time(NULL);
//    time(&time_cnt);
	time_cnt=1672588795;   
	printf("%d\n",time_cnt);
	
	time_date=*localtime(&time_cnt);
	printf("%d\n",time_date.tm_year+1900);//注意,程序里的年是从1900年经过的年数,所以要计算出想要的年份需要+1900年的偏移 
	printf("%d\n",time_date.tm_mon+1);//同理月在程序中从1月开始计算,所以需要加1月的偏移 
	printf("%d\n",time_date.tm_mday);
	printf("%d\n",time_date.tm_hour);
	printf("%d\n",time_date.tm_min);
	printf("%d\n",time_date.tm_sec);
	printf("%d\n",time_date.tm_wday);//0代表星期天 
	
	time_cnt=mktime(&time_date);
	printf("%d\n",time_cnt);
	
	time_str=ctime(&time_cnt);
	printf(time_str);
	
    return 0;
}

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

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

相关文章

leetcode hot100 组合总和Ⅲ

本题中&#xff0c;要求我们求在1-9范围内&#xff0c;满足k个数的和为n的组合&#xff08;组合是无序的&#xff0c;并且题目中要求不可以重复&#xff09;。 这种组合问题依旧需要用回溯算法来解决。因为我们没办法控制产生k层for循环。回溯算法的过程是构建树结构&#xff…

巴厘行记(二)——乌布之夜

欢迎览阅《巴厘行记》系列文章 巴厘行记巴厘行记&#xff08;一&#xff09;——海神庙 巴厘行记&#xff08;二&#xff09;——乌布之夜 巴厘行记&#xff08;三&#xff09;——Auntie和Mudi 巴厘行记&#xff08;四&#xff09;——乌布漫游 巴厘行记&#xff08;五&a…

【学网攻】 第(10)节 -- 路由器单臂路由配置

系列文章目录 目录 系列文章目录 文章目录 前言 一、单臂路由是什么&#xff1f; 二、实验 1.引入 实验拓扑图 PC配置 Sw配置 Router配置 实验验证 总结 文章目录 【学网攻】 第(1)节 -- 认识网络【学网攻】 第(2)节 -- 交换机认识及使用【学网攻】 第(3)节 -- 交…

Qt使用中文字符串乱码的问题

文章目录 vs编译器下第一种解决方式第二种解决方式 Qt编译器下 我们在使用qt的时候有时候会遇到打印中文字符串的时候出现中文乱码的问题&#xff0c;主要是由于Qt的QString字符串存储的方式是使用utf-8的编码方式&#xff0c;如果我们本地的文件是使用GBK方式的编码再使用中文…

Spring: alibaba代码规范校验工具checkstyle

文章目录 一、idea配置checkstyle插件二、激活CheckStyle三、配置自动格式化功能四、使用代码格式化 一、idea配置checkstyle插件 下载 Intellij IDEA Checkstyle 插件&#xff1a;File -> setting -> plugin通过关键字CheckStyle-IDEA搜索并安装。 安裝完成后重启idea…

wsl下安装ros2问题: Unable to locate package ros-humble-desktop 解决方案

❗ 问题 在wsl&#xff08;Ubuntu 22.04版本&#xff09;下安装ros的过程中&#xff0c;在执行命令 $ sudo apt install ros-humble-desktop一直弹出报错&#xff1a;Unable to locate package ros-humble-desktop 前面设置编码和添加源的过程中一直没有出现其他问题&#…

使用Docker部署MySQL并结合内网穿透实现远程访问本地数据库

文章目录 前言1 .安装Docker2. 使用Docker拉取MySQL镜像3. 创建并启动MySQL容器4. 本地连接测试4.1 安装MySQL图形化界面工具4.2 使用MySQL Workbench连接测试 5. 公网远程访问本地MySQL5.1 内网穿透工具安装5.2 创建远程连接公网地址5.3 使用固定TCP地址远程访问 前言 本文主…

【第五天】蓝桥杯备战

1、金币 https://www.lanqiao.cn/problems/357/learning/ 解法&#xff1a;暴力 import java.util.Scanner; // 1:无需package // 2: 类名必须Main, 不可修改public class Main {public static void main(String[] args) {Scanner scan new Scanner(System.in);//在此输入…

Oracle分栏(非分页)查询

不知道Oracle怎么进行数据分栏(分栏: 因数据列过长, 部分数据作为新列显示). 在这里先记录一下粗浅的查询方法. 数据源例子: select 日用百货 as cat, 手电筒 as name, 20 as amount, 2024-01-27 as dt from dualunion allselect 餐饮美食 as cat, 鸡公煲 as name, 15.9 as amo…

79 C++对象模型探索。数据语义学 - 进程内存空间布局分析

不同的数据在内存中会有不同的保存时机&#xff0c;和保存位置&#xff0c;这一节就分析这个。 当运行一个可执行文件时候&#xff0c;操作系统就会把这个可执行文件加载到内存&#xff1b;此时进程有一个虚拟的地址空间&#xff08;内存空间&#xff09;&#xff0c;如下图&a…

什么是SQL,什么是MYSQL?MYSQL的架构以及SQL执行语句的过程是什么?有哪些数据库的类型?一篇文章带你弄懂!

文章目录 前言一、为什么需要数据库二、数据库的相关概念1.什么是结构化查询语言 (SQL)2.什么是数据库管理系统 (DBMS)3.什么是 MySQL 数据库 三、数据库分类1.关系型数据库&#xff08;SQL&#xff09;2.非关系型数据库&#xff08;NoSQL&#xff09; 四、MYSQL架构1.各组件功…

奇怪问题说 - 测试篇

文章目录 1.什么是软件测试2.软件测试和开发的区别3.软件测试的发展&#xff1a;4.软件测试岗位5.软件测试在不同类型公司的定位6.一个优秀的软件测试人员具备的素质6.1综合能力6.2掌握自动化测试技术6.3优秀的测试用例设计能力6.4探索性思维6.5有责任感和一定的压力 7.软件测试…

智能优化算法 | Matlab实现霸王龙优化算法(TROA)(内含完整源码)

文章目录 效果一览文章概述源码设计参考资料效果一览 文章概述 智能优化算法 | Matlab实现霸王龙优化算法(TROA)(内含完整源码) 源码设计 %%clear all clcSearchAgents_no=50; % Number of search agentsFunction_name=</

单片机11-13

目录 蜂鸣器 蜂鸣器播放按键提示音 蜂鸣器播放音乐 AT24C02&#xff08;IIC&#xff09;总线 AT24C02数据存储 AT24C02秒表&#xff08;定时器扫描按键&#xff09; DS18B20温度传感器&#xff08;单总线&#xff09; 温度显示 温度报警器 蜂鸣器 蜂鸣器播放按键提示音…

ElasticSearch7.7.1集群搭建

前言 Elasticsearch&#xff08;ES&#xff09;是一个基于Apache Lucene的分布式、高扩展、近实时的搜索引擎&#xff0c;主要用于海量数据快速存储、实时检索、高效分析的场景。通过简单易用的RESTful API&#xff0c;Elasticsearch隐藏了Lucene的复杂性&#xff0c;使得全文搜…

kali系统下多版本JDK共存

0、前言 从上周末到这周都在做RCE(Remote Command/Code Execute&#xff0c;远程命令执行或者代码执行 )相关漏洞复现&#xff0c;像log4j2漏洞在复现过程用到的JDK有特定版本要求&#xff0c;我的kali虚拟机默认是JDK11&#xff0c;而我又不希望直接删除JDK11&#xff0c;可多…

Vue2:通过代理服务器解决跨域问题

一、场景描述 现在的项目大多数是前后端分离的。Vue前端项目通过ajax去请求后端接口的时候&#xff0c;会有同源策略的限制。从而产生跨域问题。 二、基本概念 1、什么是同源策略&#xff1f; 就是前端服务和后端服务的协议名&#xff0c;IP或主机名&#xff0c;端口号不完…

Linux进程间通信(IPC)机制之一:管道(Pipes)详解

&#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;Nonsense—Sabrina Carpenter 0:50━━━━━━️&#x1f49f;──────── 2:43 &#x1f504; ◀️ ⏸ ▶️ …

Maven讲解

介绍 Maven是一个流行的构建工具和项目管理工具&#xff0c;它主要用于Java项目的构建、依赖管理和项目报告生成。Maven通过提供一致的项目结构、自动化的构建过程和强大的依赖管理&#xff0c;简化了项目的开发和维护过程。 下面是一些Maven的主要特点和用途&#xff1a; 项…

设计模式—行为型模式之责任链模式

设计模式—行为型模式之责任链模式 责任链&#xff08;Chain of Responsibility&#xff09;模式&#xff1a;为了避免请求发送者与多个请求处理者耦合在一起&#xff0c;于是将所有请求的处理者通过前一对象记住其下一个对象的引用而连成一条链&#xff1b;当有请求发生时&am…