stm32怎么获取时间

时间: 2023-11-13 11:47:22 浏览: 257
您可以使用STM32内部的RTC模块来获取时间。 RTC模块可以连接到外部32.768kHz晶体振荡器,从而实现稳定的时间计数。 您可以使用CubeMX配置RTC,并使用HAL库函数来读取时间。 例如,可以使用以下代码来读取当前的小时数: ```c RTC_TimeTypeDef sTime; HAL_RTC_GetTime(&hrtc, &sTime, RTC_FORMAT_BIN); uint8_t hour = sTime.Hours; ``` 其中,hrtc是指向RTC的句柄,可以在main函数中初始化: ```c /* Initialize RTC */ hrtc.Instance = RTC; hrtc.Init.HourFormat = RTC_HOURFORMAT_24; hrtc.Init.AsynchPrediv = 127; hrtc.Init.SynchPrediv = 255; hrtc.Init.OutPut = RTC_OUTPUT_DISABLE; hrtc.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH; hrtc.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN; HAL_RTC_Init(&hrtc); ``` 请注意,此代码需要使用HAL库和CubeMX进行配置。
相关问题

esp8266获取网络时间stm32

### 回答1: 要在STM32上获取网络时间,可以使用ESP8266模块作为WiFi模块,连接到互联网并获取网络时间。以下是一些步骤: 1. 首先,需要将ESP8266模块连接到STM32。可以使用UART或SPI接口进行通信。 2. 接下来,需要编写ESP8266的AT指令,以连接到WiFi网络。可以使用AT+CWMODE指令将ESP8266设置为STA模式,并使用AT+CWJAP指令连接到WiFi网络。 3. 一旦ESP8266连接到WiFi网络,可以使用AT+CIPSNTPCFG指令配置SNTP服务器,并使用AT+CIPSNTPTIME指令获取网络时间。 4. 最后,将获取的网络时间传输到STM32,以便在应用程序中使用。 需要注意的是,ESP8266的AT指令可以通过串口或SPI接口发送和接收。在使用SPI接口时,需要将ESP8266设置为SPI从设备,并使用STM32作为主设备。 ### 回答2: 在iot应用中,我们经常需要获取准确的系统时间。ESP8266和STM32是常用的开发板,有很多应用需要它们来联网获取网络时间。下面将介绍如何用ESP8266获取网络时间,然后将时间发送给STM32。 1.ESP8266获取网络时间 在ESP8266上获取网络时间可以通过连接NTP服务器实现。ESP8266建议使用NTPClient库来获取时间。NTPClient库会连接NTP服务器获取UTC时间,然后将其转换为时间戳。下面是示例代码: #include <NTPClient.h> #include <ESP8266WiFi.h> #include <WiFiUdp.h> const char* ssid = "your_SSID"; const char* password = "your_PASSWORD"; WiFiUDP ntpUDP; NTPClient timeClient(ntpUDP, "pool.ntp.org"); void setup() { Serial.begin(115200); WiFi.begin(ssid, password); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting to WiFi..."); } Serial.println("Connected to WiFi"); timeClient.begin(); } void loop() { timeClient.update(); Serial.println(timeClient.getFormattedTime()); delay(1000); } 2.将获取的时间发送给STM32 有很多方式可以将获取的时间发送给STM32。以下是典型的两种方法: 方法一:通过ESP8266与STM32之间的串口通信发送时间戳 在ESP8266的setup()中添加以下代码: Serial.begin(115200); while (!Serial) { ; // wait for serial port to connect. Needed for native USB port only } Serial.write((byte *)&timeClient.getEpochTime(), sizeof(timeClient.getEpochTime())); Serial.end(); 在STM32的代码中添加以下代码,以接收ESP8266发送的时间戳: uint32_t timestamp; if(Serial.available() >= sizeof(timestamp)){ Serial.readBytes((char*)&timestamp, sizeof(timestamp)); } 方法二:通过ESP8266与STM32之间的SPI通信发送时间戳 在ESP8266的setup()函数内添加以下代码: SPIClass spi(VSPI); spi.begin(SCK, MISO, MOSI); spi.beginTransaction(SPISettings(SPI_SPEED, MSBFIRST, SPI_MODE3)); spi.transfer((uint8_t*)&(timeClient.getEpochTime()), sizeof(timeClient.getEpochTime()), nullptr, 0); spi.endTransaction(); 在STM32的代码中添加以下代码,以接收ESP8266发送的时间戳: uint32_t timestamp; HAL_SPI_Receive(&hspi1, (uint8_t*)&timestamp, sizeof(timestamp), HAL_MAX_DELAY); 以上就是ESP8266获取网络时间并将其发送给STM32的方法。需要注意,由于ESP8266和STM32的时钟频率不同,可能会导致时间误差。为了解决这个问题,可以在ESP8266和STM32中添加一个RTC芯片,以使它们的时钟同步。 ### 回答3: 如何通过 ESP8266 获取网络时间并在 STM32 上使用呢?这个过程可以分为以下几个步骤: 1. ESP8266 连接到网络 首先需要确保 ESP8266 能够成功连接到你的无线网络。你可以使用 AT 命令或者 Arduino 库来实现这个功能。例如,在 Arduino 上连接 ESP8266 可以使用 ESP8266WiFi 库和 WiFi.begin() 函数来连接网络。 2. ESP8266 向 NTP 服务器请求时间 ESP8266 可以通过连接 NTP 服务器获取网络时间。NTP(Network Time Protocol)是一种用来同步计算机时间的协议。ESP8266 使用 UDP 协议发送一个请求到 NTP 服务器,服务器则会向 ESP8266 发送一个包含时间信息的响应。 在 Arduino 上,你可以使用 ESP8266WiFiUdp 库中的 Udp.begin() 函数和 Udp.parsePacket() 函数来实现发送和接收网络数据包,例如: ```C++ #include <ESP8266WiFi.h> #include <WiFiUdp.h> // UDP 套接字对象 WiFiUDP udp; void setup() { // 连接到无线网络 WiFi.begin("SSID", "password"); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting..."); } // 开始 UDP udp.begin(123); } void loop() { byte packetBuffer[48]; memset(packetBuffer, 0, 48); // 向 0.cn.pool.ntp.org 请求时间 IPAddress ntpServerIP; WiFi.hostByName("0.cn.pool.ntp.org", ntpServerIP); // 构造 NTP 数据包 packetBuffer[0] = 0b11100011; // NTP 协议版本和信息 packetBuffer[1] = 0; // 应答问题和公共储存器 packetBuffer[2] = 6; // 总共8个字节的时间信息 packetBuffer[3] = 0xEC; // 标准 NTP 字头 packetBuffer[12] = 49; // 时间戳开始于第34个字符 // 发送 NTP 请求 udp.beginPacket(ntpServerIP, 123); udp.write(packetBuffer, 48); udp.endPacket(); // 等待 NTP 响应 delay(1000); int cb = udp.parsePacket(); if (!cb) { Serial.println("No packet yet"); } else { Serial.print("Packet received, length="); Serial.println(cb); udp.read(packetBuffer, 48); // 从 NTP 数据包中提取时间信息,这里假设数据包已经按照 NTP 规定返回 unsigned long highWord = word(packetBuffer[40], packetBuffer[41]); unsigned long lowWord = word(packetBuffer[42], packetBuffer[43]); unsigned long secsSince1900 = highWord << 16 | lowWord; const unsigned long seventyYears = 2208988800UL; unsigned long epoch = secsSince1900 - seventyYears; Serial.print("Unix time = "); Serial.println(epoch); } } ``` 3. 通过串口将时间传输到 STM32 上 得到时间之后,我们需要将其传输到 STM32 上。可以使用串口将时间信息发送到 STM32。在 Arduino 上,你可以使用 Serial 库来实现。例如: ```C++ Serial.print("Unix time = "); Serial.println(epoch); ``` 在 STM32 上,你需要使用一个串口接收器来接收这个时间信息。你可以使用 ST 电子的 USART 库来实现这个功能。例如: ```C++ #include <STM32F4xx.h> #include <stm32f4xx_usart.h> void USART2_Init(void) { // 初始化 USART2 USART_InitTypeDef USART_InitStruct; RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); USART_InitStruct.USART_BaudRate = 9600; USART_InitStruct.USART_WordLength = USART_WordLength_8b; USART_InitStruct.USART_StopBits = USART_StopBits_1; USART_InitStruct.USART_Parity = USART_Parity_No; USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStruct.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART2, &USART_InitStruct); USART_Cmd(USART2, ENABLE); } void USART2_SendChar(char c) { // 发送字符到 USART2 while (USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET); USART_SendData(USART2, c); } void USART2_SendString(char* s) { // 发送字符串到 USART2 while (*s) { USART2_SendChar(*s++); } } void USART2_ReceiveChar(char* c) { // 从 USART2 接收字符 while (USART_GetFlagStatus(USART2, USART_FLAG_RXNE) == RESET); *c = USART_ReceiveData(USART2); } ``` 4. STM32 接收并处理时间信息 最后,STM32 需要接收并处理 ESP8266 传来的时间信息。你可以使用 USART 库来接收 ESP8266 传来的时间信息,并使用 RTC 库来设置 STM32 的内部实时时钟。例如: ```C++ #include <STM32F4xx.h> #include <stm32f4xx_rcc.h> #include <stm32f4xx_gpio.h> #include <stm32f4xx_usart.h> #include <stm32f4xx_rtc.h> void USART2_Init(void); void USART2_SendChar(char c); void USART2_SendString(char* s); void USART2_ReceiveChar(char* c); void RTC_Init(void); void RTC_SetDateTime(uint8_t year, uint8_t month, uint8_t day, uint8_t hour, uint8_t min, uint8_t sec); int main(void) { // 初始化 RCC、GPIO、USART2 和 RTC RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE); USART2_Init(); RTC_Init(); // 接收 ESP8266 发送过来的时间信息,并设置 RTC 时间 int received = 0; char timeBuffer[12]; while (received < 12) { char c; USART2_ReceiveChar(&c); timeBuffer[received++] = c; } int year = (timeBuffer[0] - '0') * 10 + (timeBuffer[1] - '0') + 2000; int month = (timeBuffer[2] - '0') * 10 + (timeBuffer[3] - '0'); int day = (timeBuffer[4] - '0') * 10 + (timeBuffer[5] - '0'); int hour = (timeBuffer[6] - '0') * 10 + (timeBuffer[7] - '0'); int minute = (timeBuffer[8] - '0') * 10 + (timeBuffer[9] - '0'); int second = (timeBuffer[10] - '0') * 10 + (timeBuffer[11] - '0'); RTC_SetDateTime(year, month, day, hour, minute, second); // 循环等待 while (1) { } } void USART2_Init(void) { // 初始化 USART2 USART_InitTypeDef USART_InitStruct; GPIO_InitTypeDef GPIO_InitStruct; NVIC_InitTypeDef NVIC_InitStruct; // 配置 GPIO GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6; GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStruct.GPIO_OType = GPIO_OType_PP; GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOD, &GPIO_InitStruct); GPIO_PinAFConfig(GPIOD, GPIO_PinSource5, GPIO_AF_USART2); GPIO_PinAFConfig(GPIOD, GPIO_PinSource6, GPIO_AF_USART2); // 配置 NVIC 中断 NVIC_InitStruct.NVIC_IRQChannel = USART2_IRQn; NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0; NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStruct); // 配置 USART USART_InitStruct.USART_BaudRate = 9600; USART_InitStruct.USART_WordLength = USART_WordLength_8b; USART_InitStruct.USART_StopBits = USART_StopBits_1; USART_InitStruct.USART_Parity = USART_Parity_No; USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStruct.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART2, &USART_InitStruct); USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); // 启用 USART USART_Cmd(USART2, ENABLE); } void USART2_SendChar(char c) { // 发送字符到 USART2 while (USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET); USART_SendData(USART2, c); } void USART2_SendString(char* s) { // 发送字符串到 USART2 while (*s) { USART2_SendChar(*s++); } } void USART2_ReceiveChar(char* c) { // 从 USART2 接收字符 while (USART_GetFlagStatus(USART2, USART_FLAG_RXNE) == RESET); *c = USART_ReceiveData(USART2); } void RTC_Init(void) { // 使能 PWR 和 BKP 备份访问 PWR_BackupAccessCmd(ENABLE); // 使能 RTC 时钟 RCC_LSICmd(ENABLE); while (RCC_GetFlagStatus(RCC_FLAG_LSIRDY) == RESET); RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI); RCC_RTCCLKCmd(ENABLE); RTC_InitTypeDef RTC_InitStruct; RTC_InitStruct.RTC_AsynchPrediv = 0x7F; RTC_InitStruct.RTC_SynchPrediv = 0x00FF; RTC_InitStruct.RTC_HourFormat = RTC_HourFormat_24; RTC_Init(&RTC_InitStruct); // 启用 RTC 中断 RTC_ITConfig(RTC_IT_SEC, ENABLE); NVIC_InitTypeDef NVIC_InitStruct; NVIC_InitStruct.NVIC_IRQChannel = RTC_IRQn; NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0; NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStruct); // 等待 Sycn 秒钟后设置 RTC 时间 RTC_WaitForSynchro(); } void RTC_SetDateTime(uint8_t year, uint8_t month, uint8_t day, uint8_t hour, uint8_t min, uint8_t sec) { // 设置 RTC 时间 RTC_TimeTypeDef RTC_TimeStruct; RTC_DateTypeDef RTC_DateStruct; RTC_TimeStruct.RTC_Hours = hour; RTC_TimeStruct.RTC_Minutes = min; RTC_TimeStruct.RTC_Seconds = sec; RTC_TimeStruct.RTC_H12 = RTC_H12_AM; RTC_SetTime(RTC_Format_BIN, &RTC_TimeStruct); RTC_DateStruct.RTC_Year = year - 2000; RTC_DateStruct.RTC_Month = month; RTC_DateStruct.RTC_Date = day; RTC_DateStruct.RTC_WeekDay = RTC_Weekday_Monday; RTC_SetDate(RTC_Format_BIN, &RTC_DateStruct); } void RTC_IRQHandler(void) { // RTC 中断处理 if (RTC_GetITStatus(RTC_IT_SEC) == SET) { USART2_SendString("RTC second interrupt\r\n"); RTC_ClearITPendingBit(RTC_IT_SEC); } } ``` 综上,通过以上步骤,我们就可以通过 ESP8266 获取网络时间并在 STM32 上使用了。
阅读全文

相关推荐

最新推荐

recommend-type

stm32通过年月日计算星期

在STM32开发过程中,有时我们需要处理时间相关的计算,比如根据年月日计算星期。这个任务涉及到日期和时间的处理,以及闰年规则的理解。 首先,我们来探讨如何确定一个年份是否为闰年。闰年的规则是基于地球围绕...
recommend-type

基于STM32步进电机加减速控制查表法

在基于STM32的步进电机控制系统中,加减速控制是一项关键任务,它关系到电机运行的平稳性和效率。查表法是一种常见的实现步进电机加减速策略的方法,通过预先计算好不同速度阶段对应的脉冲间隔,从而实现平滑的速度...
recommend-type

STM32F103RET6TR中文数据手册.pdf

STM32F103RET6TR是一款基于ARM Cortex-M3内核的32位微控制器,由意法半导体(STMicroelectronics...开发人员可以利用STM32F103RET6TR的数据手册获取详细的技术规格和编程指南,以充分利用其功能并进行有效的系统设计。
recommend-type

富锂锰基正极材料行业研究报告 新能源材料技术 富锂锰基正极材料 行业分析 应用

富锂锰基正极材料作为一种高比容量、高能量密度的锂离子电池材料,具有减少稀有金属需求和较低环境污染的优势。文件涵盖了富锂锰基正极材料的工艺流程、评价指标、性能对比、核心技术及产业化应用情况,以及产业链结构和市场分析。适用于新能源材料研发人员、电池制造商和行业分析师,旨在提供技术进展、市场趋势和产业布局的参考。
recommend-type

Angular实现MarcHayek简历展示应用教程

资源摘要信息:"MarcHayek-CV:我的简历的Angular应用" Angular 应用是一个基于Angular框架开发的前端应用程序。Angular是一个由谷歌(Google)维护和开发的开源前端框架,它使用TypeScript作为主要编程语言,并且是单页面应用程序(SPA)的优秀解决方案。该应用不仅展示了Marc Hayek的个人简历,而且还介绍了如何在本地环境中设置和配置该Angular项目。 知识点详细说明: 1. Angular 应用程序设置: - Angular 应用程序通常依赖于Node.js运行环境,因此首先需要全局安装Node.js包管理器npm。 - 在本案例中,通过npm安装了两个开发工具:bower和gulp。bower是一个前端包管理器,用于管理项目依赖,而gulp则是一个自动化构建工具,用于处理如压缩、编译、单元测试等任务。 2. 本地环境安装步骤: - 安装命令`npm install -g bower`和`npm install --global gulp`用来全局安装这两个工具。 - 使用git命令克隆远程仓库到本地服务器。支持使用SSH方式(`***:marc-hayek/MarcHayek-CV.git`)和HTTPS方式(需要替换为具体用户名,如`git clone ***`)。 3. 配置流程: - 在server文件夹中的config.json文件里,需要添加用户的电子邮件和密码,以便该应用能够通过内置的联系功能发送信息给Marc Hayek。 - 如果想要在本地服务器上运行该应用程序,则需要根据不同的环境配置(开发环境或生产环境)修改config.json文件中的“baseURL”选项。具体而言,开发环境下通常设置为“../build”,生产环境下设置为“../bin”。 4. 使用的技术栈: - JavaScript:虽然没有直接提到,但是由于Angular框架主要是用JavaScript来编写的,因此这是必须理解的核心技术之一。 - TypeScript:Angular使用TypeScript作为开发语言,它是JavaScript的一个超集,添加了静态类型检查等功能。 - Node.js和npm:用于运行JavaScript代码以及管理JavaScript项目的依赖。 - Git:版本控制系统,用于代码的版本管理及协作开发。 5. 关于项目结构: - 该应用的项目文件夹结构可能遵循Angular CLI的典型结构,包含了如下目录:app(存放应用组件)、assets(存放静态资源如图片、样式表等)、environments(存放环境配置文件)、server(存放服务器配置文件如上文的config.json)等。 6. 开发和构建流程: - 开发时,可能会使用Angular CLI来快速生成组件、服务等,并利用热重载等特性进行实时开发。 - 构建应用时,通过gulp等构建工具可以进行代码压缩、ES6转译、单元测试等自动化任务,以确保代码的质量和性能优化。 7. 部署: - 项目最终需要部署到服务器上,配置文件中的“baseURL”选项指明了服务器上的资源基础路径。 8. 关于Git仓库: - 压缩包子文件的名称为MarcHayek-CV-master,表明这是一个使用Git版本控制的仓库,且存在一个名为master的分支,这通常是项目的主分支。 以上知识点围绕Angular应用“MarcHayek-CV:我的简历”的创建、配置、开发、构建及部署流程进行了详细说明,涉及了前端开发中常见的工具、技术及工作流。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

深入剖析:内存溢出背后的原因、预防及应急策略(专家版)

![深入剖析:内存溢出背后的原因、预防及应急策略(专家版)](https://d8it4huxumps7.cloudfront.net/uploads/images/65e82a01a4196_dangling_pointer_in_c_2.jpg?d=2000x2000) 参考资源链接:[Net 内存溢出(System.OutOfMemoryException)的常见情况和处理方式总结](https://wenku.csdn.net/doc/6412b784be7fbd1778d4a95f?spm=1055.2635.3001.10343) # 1. 内存溢出的概念及影响 内存溢出,又称
recommend-type

Java中如何对年月日时分秒的日期字符串作如下处理:如何日期分钟介于两个相连的半点之间,就将分钟数调整为前半点

在Java中,你可以使用`java.time`包中的类来处理日期和时间,包括格式化和调整。下面是一个示例,展示了如何根据给定的日期字符串(假设格式为"yyyy-MM-dd HH:mm:ss")进行这样的处理: ```java import java.text.SimpleDateFormat; import java.time.LocalDateTime; import java.time.ZoneId; import java.time.ZonedDateTime; public class Main { public static void main(String[] args
recommend-type

Crossbow Spot最新更新 - 获取Chrome扩展新闻

资源摘要信息:"Crossbow Spot - Latest News Update-crx插件" 该信息是关于一款特定的Google Chrome浏览器扩展程序,名为"Crossbow Spot - Latest News Update"。此插件的目的是帮助用户第一时间获取最新的Crossbow Spot相关信息,它作为一个RSS阅读器,自动聚合并展示Crossbow Spot的最新新闻内容。 从描述中可以提取以下关键知识点: 1. 功能概述: - 扩展程序能让用户领先一步了解Crossbow Spot的最新消息,提供实时更新。 - 它支持自动更新功能,用户不必手动点击即可刷新获取最新资讯。 - 用户界面设计灵活,具有美观的新闻小部件,使得信息的展现既实用又吸引人。 2. 用户体验: - 桌面通知功能,通过Chrome的新通知中心托盘进行实时推送,确保用户不会错过任何重要新闻。 - 提供一个便捷的方式来保持与Crossbow Spot最新动态的同步。 3. 语言支持: - 该插件目前仅支持英语,但开发者已经计划在未来的版本中添加对其他语言的支持。 4. 技术实现: - 此扩展程序是基于RSS Feed实现的,即从Crossbow Spot的RSS源中提取最新新闻。 - 扩展程序利用了Chrome的通知API,以及RSS Feed处理机制来实现新闻的即时推送和展示。 5. 版权与免责声明: - 所有的新闻内容都是通过RSS Feed聚合而来,扩展程序本身不提供原创内容。 - 用户在使用插件时应遵守相关的版权和隐私政策。 6. 安装与使用: - 用户需要从Chrome网上应用店下载.crx格式的插件文件,即Crossbow_Spot_-_Latest_News_Update.crx。 - 安装后,插件会自动运行,并且用户可以对其进行配置以满足个人偏好。 从以上信息可以看出,该扩展程序为那些对Crossbow Spot感兴趣或需要密切跟进其更新的用户提供了一个便捷的解决方案,通过集成RSS源和Chrome通知机制,使得信息获取变得更加高效和及时。这对于需要实时更新信息的用户而言,具有一定的实用价值。同时,插件的未来发展计划中包括了多语言支持,这将使得更多的用户能够使用并从中受益。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依