stm32驱动开发与linux驱动的区别

stm32,gpio设置原理
在这里插入图片描述
在这里插入图片描述

下图,定义了gpio E的基地址,只要将这个地址强制转换成gpiotypedf的类型,解析时,结构体地址就会自增。这样就可以对不同gpio组,就像定义。
在这里插入图片描述
全部gpio定义,强制为结构体类型,指向这个结构体地址
在这里插入图片描述
在这里插入图片描述
他们地址偏移量,都事先定义好。
在这里插入图片描述

如下设置gpio模式,定义好结构体 GPIO_InitTypeDef GPIO_InitStructure,设置好模式,只需将gpiof传给api,就可以设置到gpio f。
在这里插入图片描述

void KEY_Init(void)
{GPIO_InitTypeDef  GPIO_InitStructure;RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA|RCC_AHB1Periph_GPIOE, ENABLE);//ʹÄÜGPIOA,GPIOEʱÖÓGPIO_InitStructure.GPIO_Pin = GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4; //KEY0 KEY1 KEY2¶ÔÓ¦Òý½ÅGPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;//ÆÕͨÊäÈëģʽGPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MGPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//ÉÏÀ­GPIO_Init(GPIOE, &GPIO_InitStructure);//³õʼ»¯GPIOE2,3,4GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;//WK_UP¶ÔÓ¦Òý½ÅPA0GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_DOWN ;//ÏÂÀ­GPIO_Init(GPIOA, &GPIO_InitStructure);//³õʼ»¯GPIOA0} 
void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct)
{uint32_t pinpos = 0x00, pos = 0x00 , currentpin = 0x00;/* Check the parameters */assert_param(IS_GPIO_ALL_PERIPH(GPIOx));assert_param(IS_GPIO_PIN(GPIO_InitStruct->GPIO_Pin));assert_param(IS_GPIO_MODE(GPIO_InitStruct->GPIO_Mode));assert_param(IS_GPIO_PUPD(GPIO_InitStruct->GPIO_PuPd));/* ------------------------- Configure the port pins ---------------- *//*-- GPIO Mode Configuration --*/for (pinpos = 0x00; pinpos < 0x10; pinpos++){pos = ((uint32_t)0x01) << pinpos;/* Get the port pins position */currentpin = (GPIO_InitStruct->GPIO_Pin) & pos;if (currentpin == pos){GPIOx->MODER  &= ~(GPIO_MODER_MODER0 << (pinpos * 2));GPIOx->MODER |= (((uint32_t)GPIO_InitStruct->GPIO_Mode) << (pinpos * 2));if ((GPIO_InitStruct->GPIO_Mode == GPIO_Mode_OUT) || (GPIO_InitStruct->GPIO_Mode == GPIO_Mode_AF)){/* Check Speed mode parameters */assert_param(IS_GPIO_SPEED(GPIO_InitStruct->GPIO_Speed));/* Speed mode configuration */GPIOx->OSPEEDR &= ~(GPIO_OSPEEDER_OSPEEDR0 << (pinpos * 2));GPIOx->OSPEEDR |= ((uint32_t)(GPIO_InitStruct->GPIO_Speed) << (pinpos * 2));/* Check Output mode parameters */assert_param(IS_GPIO_OTYPE(GPIO_InitStruct->GPIO_OType));/* Output mode configuration*/GPIOx->OTYPER  &= ~((GPIO_OTYPER_OT_0) << ((uint16_t)pinpos)) ;GPIOx->OTYPER |= (uint16_t)(((uint16_t)GPIO_InitStruct->GPIO_OType) << ((uint16_t)pinpos));}/* Pull-up Pull down resistor configuration*/GPIOx->PUPDR &= ~(GPIO_PUPDR_PUPDR0 << ((uint16_t)pinpos * 2));GPIOx->PUPDR |= (((uint32_t)GPIO_InitStruct->GPIO_PuPd) << (pinpos * 2));}}
}
void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)
{/* Check the parameters */assert_param(IS_GPIO_ALL_PERIPH(GPIOx));assert_param(IS_GPIO_PIN(GPIO_Pin));GPIOx->BSRRL = GPIO_Pin;
}

如下,也是可以直接这样设置的,不需传gpiox
在这里插入图片描述

在这里插入图片描述

由于不止一种gpio结构体属性,由是定义了很多结构体,描述不同属性

typedef struct
{__IO uint32_t CR;       /*!< DCMI control register 1,                       Address offset: 0x00 */__IO uint32_t SR;       /*!< DCMI status register,                          Address offset: 0x04 */__IO uint32_t RISR;     /*!< DCMI raw interrupt status register,            Address offset: 0x08 */__IO uint32_t IER;      /*!< DCMI interrupt enable register,                Address offset: 0x0C */__IO uint32_t MISR;     /*!< DCMI masked interrupt status register,         Address offset: 0x10 */__IO uint32_t ICR;      /*!< DCMI interrupt clear register,                 Address offset: 0x14 */__IO uint32_t ESCR;     /*!< DCMI embedded synchronization code register,   Address offset: 0x18 */__IO uint32_t ESUR;     /*!< DCMI embedded synchronization unmask register, Address offset: 0x1C */__IO uint32_t CWSTRTR;  /*!< DCMI crop window start,                        Address offset: 0x20 */__IO uint32_t CWSIZER;  /*!< DCMI crop window size,                         Address offset: 0x24 */__IO uint32_t DR;       /*!< DCMI data register,                            Address offset: 0x28 */
} DCMI_TypeDef;/** * @brief DMA Controller*/typedef struct
{__IO uint32_t CR;     /*!< DMA stream x configuration register      */__IO uint32_t NDTR;   /*!< DMA stream x number of data register     */__IO uint32_t PAR;    /*!< DMA stream x peripheral address register */__IO uint32_t M0AR;   /*!< DMA stream x memory 0 address register   */__IO uint32_t M1AR;   /*!< DMA stream x memory 1 address register   */__IO uint32_t FCR;    /*!< DMA stream x FIFO control register       */
} DMA_Stream_TypeDef;typedef struct
{__IO uint32_t LISR;   /*!< DMA low interrupt status register,      Address offset: 0x00 */__IO uint32_t HISR;   /*!< DMA high interrupt status register,     Address offset: 0x04 */__IO uint32_t LIFCR;  /*!< DMA low interrupt flag clear register,  Address offset: 0x08 */__IO uint32_t HIFCR;  /*!< DMA high interrupt flag clear register, Address offset: 0x0C */
} DMA_T

2、stm32和arm linux一样,将中断进行编号

typedef enum IRQn
{
/******  Cortex-M4 Processor Exceptions Numbers ****************************************************************/NonMaskableInt_IRQn         = -14,    /*!< 2 Non Maskable Interrupt                                          */MemoryManagement_IRQn       = -12,    /*!< 4 Cortex-M4 Memory Management Interrupt                           */BusFault_IRQn               = -11,    /*!< 5 Cortex-M4 Bus Fault Interrupt                                   */UsageFault_IRQn             = -10,    /*!< 6 Cortex-M4 Usage Fault Interrupt                                 */SVCall_IRQn                 = -5,     /*!< 11 Cortex-M4 SV Call Interrupt                                    */DebugMonitor_IRQn           = -4,     /*!< 12 Cortex-M4 Debug Monitor Interrupt                              */PendSV_IRQn                 = -2,     /*!< 14 Cortex-M4 Pend SV Interrupt                                    */SysTick_IRQn                = -1,     /*!< 15 Cortex-M4 System Tick Interrupt                                */
/******  STM32 specific Interrupt Numbers **********************************************************************/WWDG_IRQn                   = 0,      /*!< Window WatchDog Interrupt                                         */PVD_IRQn                    = 1,      /*!< PVD through EXTI Line detection Interrupt                         */TAMP_STAMP_IRQn             = 2,      /*!< Tamper and TimeStamp interrupts through the EXTI line             */RTC_WKUP_IRQn               = 3,      /*!< RTC Wakeup interrupt through the EXTI line                        */FLASH_IRQn                  = 4,      /*!< FLASH global Interrupt                                            */RCC_IRQn                    = 5,      /*!< RCC global Interrupt                                              */EXTI0_IRQn                  = 6,      /*!< EXTI Line0 Interrupt                                              */EXTI1_IRQn                  = 7,      /*!< EXTI Line1 Interrupt                                              */EXTI2_IRQn                  = 8,      /*!< EXTI Line2 Interrupt                                              */EXTI3_IRQn                  = 9,      /*!< EXTI Line3 Interrupt                                              */EXTI4_IRQn                  = 10,     /*!< EXTI Line4 Interrupt                                              */DMA1_Stream0_IRQn           = 11,     /*!< DMA1 Stream 0 global Interrupt                                    */DMA1_Stream1_IRQn           = 12,     /*!< DMA1 Stream 1 global Interrupt                                    */DMA1_Stream2_IRQn           = 13,     /*!< DMA1 Stream 2 global Interrupt                                    */DMA1_Stream3_IRQn           = 14,     /*!< DMA1 Stream 3 global Interrupt                                    */DMA1_Stream4_IRQn           = 15,     /*!< DMA1 Stream 4 global Interrupt                                    */DMA1_Stream5_IRQn           = 16,     /*!< DMA1 Stream 5 global Interrupt                                    */DMA1_Stream6_IRQn           = 17,     /*!< DMA1 Stream 6 global Interrupt                                    */ADC_IRQn                    = 18,     /*!< ADC1, ADC2 and ADC3 global Interrupts                             */#if defined (STM32F40_41xxx)CAN1_TX_IRQn                = 19,     /*!< CAN1 TX Interrupt                                                 */CAN1_RX0_IRQn               = 20,     /*!< CAN1 RX0 Interrupt                                                */CAN1_RX1_IRQn               = 21,     /*!< CAN1 RX1 Interrupt                                                */CAN1_SCE_IRQn               = 22,     /*!< CAN1 SCE Interrupt                                                */EXTI9_5_IRQn                = 23,     /*!< External Line[9:5] Interrupts                                     */TIM1_BRK_TIM9_IRQn          = 24,     /*!< TIM1 Break interrupt and TIM9 global interrupt                    */TIM1_UP_TIM10_IRQn          = 25,     /*!< TIM1 Update Interrupt and TIM10 global interrupt                  */TIM1_TRG_COM_TIM11_IRQn     = 26,     /*!< TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt */TIM1_CC_IRQn                = 27,     /*!< TIM1 Capture Compare Interrupt                                    */TIM2_IRQn                   = 28,     /*!< TIM2 global Interrupt                                             */TIM3_IRQn                   = 29,     /*!< TIM3 global Interrupt                                             */TIM4_IRQn                   = 30,     /*!< TIM4 global Interrupt                                             */I2C1_EV_IRQn                = 31,     /*!< I2C1 Event Interrupt                                              */I2C1_ER_IRQn                = 32,     /*!< I2C1 Error Interrupt                                              */I2C2_EV_IRQn                = 33,     /*!< I2C2 Event Interrupt                                              */I2C2_ER_IRQn                = 34,     /*!< I2C2 Error Interrupt                                              */SPI1_IRQn                   = 35,     /*!< SPI1 global Interrupt                                             */SPI2_IRQn                   = 36,     /*!< SPI2 global Interrupt                                             */USART1_IRQn                 = 37,     /*!< USART1 global Interrupt                                           */USART2_IRQn                 = 38,     /*!< USART2 global Interrupt                                           */USART3_IRQn                 = 39,     /*!< USART3 global Interrupt                                           */EXTI15_10_IRQn              = 40,     /*!< External Line[15:10] Interrupts                                   */RTC_Alarm_IRQn              = 41,     /*!< RTC Alarm (A and B) through EXTI Line Interrupt                   */OTG_FS_WKUP_IRQn            = 42,     /*!< USB OTG FS Wakeup through EXTI line interrupt                     */TIM8_BRK_TIM12_IRQn         = 43,     /*!< TIM8 Break Interrupt and TIM12 global interrupt                   */TIM8_UP_TIM13_IRQn          = 44,     /*!< TIM8 Update Interrupt and TIM13 global interrupt                  */TIM8_TRG_COM_TIM14_IRQn     = 45,     /*!< TIM8 Trigger and Commutation Interrupt and TIM14 global interrupt */TIM8_CC_IRQn                = 46,     /*!< TIM8 Capture Compare Interrupt                                    */DMA1_Stream7_IRQn           = 47,     /*!< DMA1 Stream7 Interrupt                                            */FSMC_IRQn                   = 48,     /*!< FSMC global Interrupt                                             */SDIO_IRQn                   = 49,     /*!< SDIO global Interrupt                                             */TIM5_IRQn                   = 50,     /*!< TIM5 global Interrupt                                             */SPI3_IRQn                   = 51,     /*!< SPI3 global Interrupt                                             */UART4_IRQn                  = 52,     /*!< UART4 global Interrupt                                            */UART5_IRQn                  = 53,     /*!< UART5 global Interrupt                                            */TIM6_DAC_IRQn               = 54,     /*!< TIM6 global and DAC1&2 underrun error  interrupts                 */TIM7_IRQn                   = 55,     /*!< TIM7 global interrupt                                             */DMA2_Stream0_IRQn           = 56,     /*!< DMA2 Stream 0 global Interrupt                                    */DMA2_Stream1_IRQn           = 57,     /*!< DMA2 Stream 1 global Interrupt                                    */DMA2_Stream2_IRQn           = 58,     /*!< DMA2 Stream 2 global Interrupt                                    */DMA2_Stream3_IRQn           = 59,     /*!< DMA2 Stream 3 global Interrupt                                    */DMA2_Stream4_IRQn           = 60,     /*!< DMA2 Stream 4 global Interrupt                                    */ETH_IRQn                    = 61,     /*!< Ethernet global Interrupt                                         */ETH_WKUP_IRQn               = 62,     /*!< Ethernet Wakeup through EXTI line Interrupt                       */CAN2_TX_IRQn                = 63,     /*!< CAN2 TX Interrupt                                                 */CAN2_RX0_IRQn               = 64,     /*!< CAN2 RX0 Interrupt                                                */CAN2_RX1_IRQn               = 65,     /*!< CAN2 RX1 Interrupt                                                */CAN2_SCE_IRQn               = 66,     /*!< CAN2 SCE Interrupt                                                */OTG_FS_IRQn                 = 67,     /*!< USB OTG FS global Interrupt                                       */DMA2_Stream5_IRQn           = 68,     /*!< DMA2 Stream 5 global interrupt                                    */DMA2_Stream6_IRQn           = 69,     /*!< DMA2 Stream 6 global interrupt                                    */DMA2_Stream7_IRQn           = 70,     /*!< DMA2 Stream 7 global interrupt                                    */USART6_IRQn                 = 71,     /*!< USART6 global interrupt                                           */I2C3_EV_IRQn                = 72,     /*!< I2C3 event interrupt                                              */I2C3_ER_IRQn                = 73,     /*!< I2C3 error interrupt                                              */OTG_HS_EP1_OUT_IRQn         = 74,     /*!< USB OTG HS End Point 1 Out global interrupt                       */OTG_HS_EP1_IN_IRQn          = 75,     /*!< USB OTG HS End Point 1 In global interrupt                        */OTG_HS_WKUP_IRQn            = 76,     /*!< USB OTG HS Wakeup through EXTI interrupt                          */OTG_HS_IRQn                 = 77,     /*!< USB OTG HS global interrupt                                       */DCMI_IRQn                   = 78,     /*!< DCMI global interrupt                                             */CRYP_IRQn                   = 79,     /*!< CRYP crypto global interrupt                                      */HASH_RNG_IRQn               = 80,     /*!< Hash and Rng global interrupt                                     */FPU_IRQn      

arm linux驱动开发也是一样的,这部分寄存器定义,由芯片厂商完成,驱动移植者,只需要调用设置就可以了。stm32只是没有操作系统,来管理应用程序,驱动,linux有操作系统,进程管理,来调度驱动。

stm32官方定义好的gpio设置api

void GPIO_Write(GPIO_TypeDef* GPIOx, uint16_t PortVal)
{/* Check the parameters */assert_param(IS_GPIO_ALL_PERIPH(GPIOx));GPIOx->ODR = PortVal;
}
  */
uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx)
{/* Check the parameters */assert_param(IS_GPIO_ALL_PERIPH(GPIOx));return ((uint16_t)GPIOx->ODR);
}
void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)
{/* Check the parameters */assert_param(IS_GPIO_ALL_PERIPH(GPIOx));assert_param(IS_GPIO_PIN(GPIO_Pin));GPIOx->BSRRL = GPIO_Pin;
}
void GPIO_ResetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)
{/* Check the parameters */assert_param(IS_GPIO_ALL_PERIPH(GPIOx));assert_param(IS_GPIO_PIN(GPIO_Pin));GPIOx->BSRRH = GPIO_Pin;
}

其实linux也是一样的,这部分有linux官方已经定义好统一的接口,芯片厂商,调用接口,对接自己的gpio,寄存器,设置好就可以了。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

有些不按gpio的标准写驱动,和stm32一样,直接操作寄存器。
在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux CentOS更换阿里云源解决Could not retrieve mirrorlist http://mirrorlist.centos.org

Linux CentOS7 更新yum 操作的时候出现这个问题&#xff1a; Loading mirror speeds from cached hostfile Could not retrieve mirrorlist http://mirrorlist.centos.org 然后我执行 grep -nr "mirrorlist.centos.org" /etc/yum.repos.d/* 出现 这个问题时可以…

搭建 WordPress 及常见问题与解决办法

浪浪云活动链接 &#xff1a;https://langlangy.cn/?i8afa52 文章目录 环境准备安装 LAMP 堆栈 (Linux, Apache, MySQL, PHP)配置 MySQL 数据库 安装 WordPress配置 WordPress常见问题及解决办法数据库连接错误白屏问题插件或主题冲突内存限制错误 本文旨在介绍如何在服务器上…

爬虫使用代理IP后报错?解决方案在这里!

在数据抓取的过程中&#xff0c;使用代理IP是避免被封禁、提高抓取效率的重要手段。然而&#xff0c;有时候即使配置了代理IP&#xff0c;依然会遇到各种报错问题。本文将详细解析常见的报错类型&#xff0c;并提供解决方案&#xff0c;帮助你顺利进行数据抓取。 常见报错类型…

MySQL表的操作与数据类型

目录 前言 一、表的操作 1.创建一个表 2.查看表的结构 3.修改表 4.删除一个表 二、 MySQL的数据类型 0.数据类型一览&#xff1a; 1.整数类型 2.位类型 3.小数类型 4.字符类型 前言 在MySQL库的操作一文中介绍了有关MySQL库的操作&#xff0c;本节要讲解的是由库管理的结构——…

智能体 vs AI智能体:区别与联系,一文读懂!

​ 在AI技术蓬勃发展的今天&#xff0c;“智能体”&#xff08;Agent&#xff09;和”AI智能体”&#xff08;AI Agent&#xff09;两个概念经常被提及&#xff0c;二者在很多场合下会被混淆&#xff0c;但其实它们有着不同的定义和应用。我觉得很有必要小小科普下两者的定义与…

软件测试学习笔记丨Pytest的使用

本文转自测试人社区&#xff0c;原文链接&#xff1a;https://ceshiren.com/t/topic/22158 1. 简介 pytest是一个成熟的全功能python测试框架测试用例的skip和xfail&#xff0c;自动失败重试等处理能够支持简单的单元测试和复杂的功能测试&#xff0c;还可以用来做selenium/ap…

HTML的块级元素与行内元素

在HTML中&#xff0c;元素可以分为两大类&#xff1a;块级元素&#xff08;block-level elements&#xff09;和行内元素&#xff08;inline elements&#xff09;。这两种类型的元素在网页布局和呈现中扮演着不同的角色。 块级元素&#xff08;Block-level Elements&#xff…

CMU 10423 Generative AI:HW1(编程部分:在GPT-2模型中实现RoPE、GQA)

完整代码和PDF笔记&#xff1a;https://github.com/YM2025/CMU_10423_2024S 文章目录 1 概述Rotary Positional Embeddings (RoPE)Grouped Query Attention (GQA)实验任务 2 项目文件1. requirements.txt2. input.txt3. chargpt.py4. mingpt/a. model.pyb. trainer.pyc. utils.…

毕业论文选题难?5招帮你轻松搞定选题!

AIPaperGPT&#xff0c;论文写作神器~ https://www.aipapergpt.com/ 你是不是已经为毕业论文的选题愁得头发都要掉光了&#xff1f;每次打开文档&#xff0c;都觉得什么都想写&#xff0c;又好像什么都写不了。选题看起来很简单&#xff0c;但真正开始动手的时候&#xff0c;…

深入探索系统架构设计

目录 前言 软件的体系结构 软件架构定义 软件架构设计与生命周期 1、需求分析阶段 2、设计阶段 3、实现阶段 4、构件组装阶段 5、部署阶段 6、后开发阶段 软件架构的重要性 1、架构设计能够满足系统的品质 2、架构设计使受益人达成一致的目标 3、架构设计能够支持…

UDS 诊断 - RequestTransferExit(请求传输终止)(0x37)服务

UDS 诊断服务系列文章目录 诊断和通信管理功能单元 UDS 诊断 - DiagnosticSessionControl&#xff08;诊断会话控制&#xff09;&#xff08;0x10&#xff09;服务 UDS 诊断 - ECUReset&#xff08;ECU重置&#xff09;&#xff08;0x11&#xff09;服务 UDS 诊断 - SecurityA…

【北京迅为】《STM32MP157开发板使用手册》- 第二十六章Cortex-M4 GPIO_蜂鸣器实验

iTOP-STM32MP157开发板采用ST推出的双核cortex-A7单核cortex-M4异构处理器&#xff0c;既可用Linux、又可以用于STM32单片机开发。开发板采用核心板底板结构&#xff0c;主频650M、1G内存、8G存储&#xff0c;核心板采用工业级板对板连接器&#xff0c;高可靠&#xff0c;牢固耐…

matlab 基于选权迭代法的空间平面拟合

目录 一、算法原理1、参数平差2、选权迭代法3、参考文献二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接,爬虫自重。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的抄袭狗。 一、算法原理 1、参数平差 由空间几何学知,空间平面方程可以表述为: A x…

【C++】——string类的模拟实现

目录 一、string模拟实现 1.1构造析构 1.2迭代器 1.3修改 1.4查找 1.5substr 深浅拷贝的区别 1.6比较函数与流插入流提取 二、string类的拷贝 2.1浅拷贝与深拷贝 2.2传统版与现代版区别 2.3写时拷贝&#xff08;了解&#xff09; 三、vs和g下string结构的说明 3.1v…

零信任沙箱让源代码防泄漏“如虎添翼”

"数据泄露事件频发&#xff0c;给企业带来了巨大的经济损失和声誉损害。SDC沙盒&#xff0c;一款基于零信任模型构建的数据防泄密解决方案&#xff0c;正成为企业数据安全的新防线。 &#x1f510; 零信任模型的核心&#xff1a;SDC沙盒遵循“永不信任&#xff0c;始终验…

Python爬虫案例七:抓取南京公交信息数据并将其保存成excel多表形式

测试链接: https://nanjing.8684.cn/line4 思路&#xff1a;先抓取某个类型下的某一条线路所有数据&#xff0c;然后实现批量,&#xff0c;列举出三个类型代表既可 源码&#xff1a; from lxml import etree from xlutils.copy import copy import requests, os, xlrd, xlwtd…

串口输出时:英文正常输出、中文乱码输出

一、问题&#xff1a;英文正常输出&#xff0c;英文乱码输出 二、解决方法 1、查看自己使用的串口助手的编码格式 2、查看自己使用输出的文件编码格式 以记事本的格式查看&#xff0c;原则上这两种应该保持相同&#xff0c;如果不相同&#xff0c;就需要把这个文件去另保存一…

UE5 阴影通道

Shadow Pass Switch节点中 Default代表模型遮罩的效果 Shadow代表阴影的生成遮罩效果

Android Studio报错中文乱码

现象&#xff1a; 解决办法&#xff1a; 按两下Shift&#xff0c;查找Edit Custom VM Options并确认&#xff1b; 没有studio64.exe.vmoptions的话会弹窗&#xff0c;创建一个即可&#xff1b;原本存在的话&#xff0c;在最下面添加 -Dfile.encodingUTF-83. Sync Gradle 重…

开源项目chartDB体验

github地址 &#xff1a;https://github.com/chartdb/chartdb 在线网站体验&#xff1a;https://chartdb.io/ 体验后发现 chartDB的作用是可视化各个表格之间的关系&#xff0c;方便数据库设计者操作并且接上openai的接口生成各个数据库语言的代码&#xff1b;但它没法导入实际…