【STM32-学习笔记-14-】FLASH闪存

文章目录

  • FALSH闪存
    • 一、FLASH简介
    • 二、FLASH基本结构
    • 三、FLASH解锁
    • 四、使用指针访问存储器
    • 五、FLASH擦除以及编程流程
      • Ⅰ、程序存储器全擦除
          • 1. 读取FLASH_CR的LOCK位
          • 2. 检查LOCK位是否为1
          • 3. 设置FLASH_CR的MER = 1和STRT = 1(如果LOCK位=0)
          • 4. 检查FLASH_SR的BSY位
          • 5. 读取并验证所有页的数据(如果BSY位=0)
      • Ⅱ、程序存储器页擦除
          • 1. 读取FLASH_CR的LOCK位
          • 2. 检查LOCK位是否为1
          • 3. 设置FLASH_CR的PER = 1和STRT = 1(如果LOCK位=0)
          • 4. 检查FLASH_SR的BSY位
          • 5. 读取并验证被擦除页的数据(如果BSY位=0)
      • Ⅲ、程序存储器编程
          • 1. 读取FLASH_CR的LOCK位
          • 2. 检查LOCK位是否为1
          • 3. 设置FLASH_CR的PG位=1(如果LOCK位=0)
          • 4. 在指定的地址写入半字(16位)
          • 5. 检查FLASH_SR的BSY位
          • 6. 读取编程地址并检查写入的数据(如果BSY位=0)
      • Ⅳ、闪存控制寄存器(FLASH_CR)
    • 六、选项字节
      • Ⅰ、选项字节擦除
      • Ⅱ、选项字节擦除
    • 七、器件电子签名
    • 八、读写内部FLASH
      • Ⅰ、FLASH函数
      • Ⅱ、使用示例:
        • MyFALSH.c
        • MyFALSH.h
        • Store.c
        • Store.h
    • 九、读取设备ID

FALSH闪存

ICP(In-Circuit Programming)和IAP(In Application Programming)是两种不同的微控制器编程方式

  • ICP(在线编程): ICP指的是通过JTAG/SWD协议或者系统加载程序(Bootloader,串口)下载用户应用程序到微控制器中的过程。它是一种在线编程方式,允许开发者直接将程序下载到微控制器中,通常用于开发和调试阶段

  • IAP(在应用编程): IAP即在应用编程,是用户通过自己编写的程序,在程序运行过程中,对User Flash的部分区域进行烧写,达到升级固件作用的方式。IAP的目的是为了在产品发布后,可以通过预留的通信口对产品中的固件程序进行更新升级。通常,为了实现IAP功能,需要在设计固件程序时编写两个项目代码,第一个项目程序不执行正常的功能操作,而只是通过某种通信方式接收程序或数据,执行对第二部分代码的更新,这个项目程序称为boot loader程序。第二个项目代码才是真正的功能代码。 这两部分代码都同时烧录在User Flash中。IAP允许在应用程序中重新烧写闪存存储器中的内容,但需要至少有一部分程序已经使用ICP方式烧到闪存存储器中(Bootloader)。IAP可以在不需要操作硬件平台的情况下实现升级(远程)

一、FLASH简介

  • STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分,通过闪存存储器接口(外设)可以对程序存储器和选项字节进行擦除和编程

  • 读写FLASH的用途:

    • 利用程序存储器的剩余空间来保存掉电不丢失的用户数据

    • 通过在程序中编程(IAP),实现程序的自我更新

  • 在线编程(In-Circuit Programming – ICP)用于更新程序存储器的全部内容,它通过JTAG、SWD协议或系统加载程序(Bootloader)下载程序

  • 在程序中编程(In-Application Programming – IAP)可以使用微控制器支持的任一种通信接口下载程序

  • 存储器映像:

    • 类型起始地址存储器用途
      ROM0x0800 0000程序存储器Flash存储C语言编译后的程序代码
      ROM0x1FFF F000系统存储器存储BootLoader,用于串口下载
      ROM0x1FFF F800选项字节存储一些独立于程序代码的配置参数
      RAM0x2000 0000运行内存SRAM存储运行过程中的临时变量
      RAM0x4000 0000外设寄存器存储各个外设的配置参数
      RAM0xE000 0000内核外设寄存器存储内核各个外设的配置参数

二、FLASH基本结构

image-20250118113700939

image-20250118113802184

三、FLASH解锁

  • FPEC共有三个键值:

    • RDPRT键 = 0x000000A5

    • KEY1 = 0x45670123

    • KEY2 = 0xCDEF89AB

      1. RDPRT键(0x000000A5)
        • 这个键值主要用于读保护操作。在STM32中,读保护是一种安全机制,用于防止外部对FLASH存储器内容的非法读取。当需要设置或修改读保护级别时,会用到这个键值。不过在解锁FPEC的过程中,RDPRT键并不直接参与解锁操作
      2. KEY1(0x45670123)和KEY2(0xCDEF89AB)
        • 这两个键值是专门用于解锁FPEC的关键序列。在STM32的FLASH编程和擦除操作之前,必须先解锁FPEC,否则无法对FLASH控制寄存器(FLASH_CR)进行写操作
  • 解锁:

    • 复位后,FPEC被保护,不能写入FLASH_CR

    • FLASH_KEYR先写入KEY1,再写入KEY2,解锁

    • 错误的操作序列会在下次复位前锁死FPECFLASH_CR

    • 解锁步骤:

      • 首先,需要向FLASH_KEYR(FLASH钥匙寄存器)写入KEY1(0x45670123)。这一步是解锁序列的第一步,相当于输入解锁密码的第一部分
      • 紧接着,再向FLASH_KEYR写入KEY2(0xCDEF89AB)。这是解锁序列的第二步,完成这一步后,FPEC就被解锁了。解锁后,就可以对FLASH_CR进行写操作,进而进行FLASH的编程、擦除等操作了
  • 加锁: 设置FLASH_CR中的LOCK位锁住FPECFLASH_CR

    • 加锁方法

      • 加锁操作只需要设置FLASH_CR(FLASH控制寄存器)中的LOCK位为1即可。一旦LOCK位被设置,FPEC和FLASH_CR就会被锁住,直到下一次复位。这样可以有效防止在正常工作过程中,由于程序错误或其他意外情况导致FLASH内容被非法修改

四、使用指针访问存储器

  • 使用指针指定地址下的存储器:
    • uint16_t Data = *((__IO uint16_t *)(0x08000000));
      • *((__IO uint16_t *)(0x08000000)); 含义:读出0x08000000地址下的数据,每次读出16位数据
  • 使用指针指定地址下的存储器:
    • *((__IO uint16_t *)(0x08000000)) = 0x1234;
  • 其中:
    • #define __IO volatile
    • 加上volatile的目的是为防止编译器优化

五、FLASH擦除以及编程流程

Ⅰ、程序存储器全擦除

image-20250118130601773

  • 详细解释:

  • 1. 读取FLASH_CR的LOCK位
    • 操作:首先,需要检查FLASH控制寄存器(FLASH_CR)中的LOCK位的状态
    • 目的:确定FLASH是否被锁定。如果LOCK位为1,表示FLASH处于锁定状态,无法进行擦除或写入操作
    2. 检查LOCK位是否为1
    • 操作:判断LOCK位的值

      • 如果LOCK位=1:表示FLASH被锁定,需要执行解锁过程

          • 操作:按照特定的顺序和键值对FLASH进行解锁
          • 详细步骤
            1. 向FLASH_KEYR寄存器写入KEY1(0x45670123)
            2. 向FLASH_KEYR寄存器写入KEY2(0xCDEF89AB)
          • 目的:解锁FLASH,使其可以接受擦除或写入操作
      • 如果LOCK位=0:表示FLASH未被锁定,可以继续进行擦除操作

    3. 设置FLASH_CR的MER = 1和STRT = 1(如果LOCK位=0)
    • 操作:在FLASH未锁定的情况下,设置FLASH_CR寄存器中的MER(Mass Erase Request,全擦除请求)位为1,并设置STRT(Start,启动)位为1
      • STRT位为1:启动信号
      • MER位为1:表示开始全擦除
    • 目的:启动全擦除操作。MER位的设置告诉FLASH控制器需要进行全擦除,而STRT位的设置则正式触发擦除过程
    4. 检查FLASH_SR的BSY位
    • 操作:在擦除过程中,不断检查FLASH状态寄存器(FLASH_SR)中的BSY(Busy,忙碌)位
      • 如果BSY位=1:表示擦除操作正在进行中,需要继续等待
      • 如果BSY位=0:表示擦除操作已经完成,可以进行下一步操作
    5. 读取并验证所有页的数据(如果BSY位=0)
    • 操作:在擦除操作完成后,读取FLASH中所有页的数据,并进行验证,确保所有数据都被正确擦除
    • 目的:确认擦除操作的效果,确保所有数据都被成功清除

Ⅱ、程序存储器页擦除

image-20250118130830137

  • 详细解释:

  • 1. 读取FLASH_CR的LOCK位
    • 操作:首先,需要检查FLASH控制寄存器(FLASH_CR)中的LOCK位的状态
    • 目的:确定FLASH是否被锁定。如果LOCK位为1,表示FLASH处于锁定状态,无法进行擦除或写入操作
    2. 检查LOCK位是否为1
    • 操作:判断LOCK位的值

      • 如果LOCK位=1:表示FLASH被锁定,需要执行解锁过程

          • 操作:按照特定的顺序和键值对FLASH进行解锁
          • 详细步骤
            1. 向FLASH_KEYR寄存器写入KEY1(0x45670123)
            2. 向FLASH_KEYR寄存器写入KEY2(0xCDEF89AB)
          • 目的:解锁FLASH,使其可以接受擦除或写入操作
      • 如果LOCK位=0:表示FLASH未被锁定,可以继续进行擦除操作

    3. 设置FLASH_CR的PER = 1和STRT = 1(如果LOCK位=0)
    • 操作:在FLASH未锁定的情况下,设置FLASH_CR寄存器中的PER(Page Erase Request,页擦除请求)位为1,并设置STRT(Start,启动)位为1
    • 详细步骤
      1. STRT位为1:启动信号
      2. PER位为1:表示开始页擦除
      3. 根据FLASH_AR寄存器中的页起始地址,开始擦除这一页
    • 目的:启动页擦除操作。PER位的设置告诉FLASH控制器需要进行页擦除,而STRT位的设置则正式触发擦除过程
    4. 检查FLASH_SR的BSY位
    • 操作:在擦除过程中,不断检查FLASH状态寄存器(FLASH_SR)中的BSY(Busy,忙碌)位
      • 如果BSY位=1:表示擦除操作正在进行中,需要继续等待
      • 如果BSY位=0:表示擦除操作已经完成,可以进行下一步操作
    5. 读取并验证被擦除页的数据(如果BSY位=0)
    • 操作:在擦除操作完成后,读取被擦除页的数据,并进行验证,确保该页的数据都被正确擦除
    • 目的:确认擦除操作的效果,确保指定的页已经被成功清除

Ⅲ、程序存储器编程

image-20250118131332587

  • 详细解释:

  • 1. 读取FLASH_CR的LOCK位
    • 操作:首先读取FLASH控制寄存器(FLASH_CR)中的LOCK位
    • 目的:确定FLASH是否处于锁定状态,因为锁定状态下不能进行写入操作
    2. 检查LOCK位是否为1
    • 操作:判断LOCK位的值
      • 如果LOCK位=1:表示FLASH被锁定,需要执行解锁序列
      • 如果LOCK位=0:表示FLASH未被锁定,可以进行写入操作
    3. 设置FLASH_CR的PG位=1(如果LOCK位=0)
    • 操作:在FLASH未锁定的情况下,设置FLASH_CR寄存器中的PG(Program,编程)位为1
    • 目的:启动编程(写入)操作
    4. 在指定的地址写入半字(16位)
    • 操作:将需要写入的数据(半字,即16位)写入到指定的FLASH地址
      • 任何非半字的数据,FPEC都会产生总线错误
    • 一次只能写入半字(16位)
    5. 检查FLASH_SR的BSY位
    • 操作:在写入过程中,不断检查FLASH状态寄存器(FLASH_SR)中的BSY(Busy,忙碌)位
      • 如果BSY位=1:表示写入操作正在进行中,需要继续等待
      • 如果BSY位=0:表示写入操作已经完成,可以进行下一步操作
    6. 读取编程地址并检查写入的数据(如果BSY位=0)
    • 操作:在写入操作完成后,从指定的FLASH地址读取数据,并与写入的数据进行比较,以验证写入是否成功
    • 目的:确保数据正确写入到FLASH中,防止写入错误

Ⅳ、闪存控制寄存器(FLASH_CR)

image-20250118135013553

六、选项字节

image-20250118132602912

  • nUSERUSER的反码,在写入选项字节时,需要在对应位置写入其反码(硬件自动完成)(保障措施)
  • RDP:写入RDPRT键(0x000000A5)后解除读保护

  • USER:配置硬件看门狗和进入停机/待机模式是否产生复位

  • Data0/1:用户可自定义使用

  • WRP0/1/2/3:配置写保护,每一个位对应保护4个存储页(中容量)

Ⅰ、选项字节擦除

  • 检查FLASH_SRBSY位,以确认没有其他正在进行的闪存操作

  • 解锁FLASH_CROPTWRE位

  • 设置FLASH_CROPTER位为1

  • 设置FLASH_CRSTRT位为1

  • 等待BSY位变为0

  • 读出被擦除的选择字节并做验证

Ⅱ、选项字节擦除

  • 检查FLASH_SRBSY位,以确认没有其他正在进行的编程操作

  • 解锁FLASH_CROPTWRE位

  • 设置FLASH_CROPTPG位为1

  • 写入要编程的半字到指定的地址

  • 等待BSY位变为0

  • 读出写入的地址并验证数据

七、器件电子签名

  • 电子签名存放在闪存存储器模块的系统存储区域,包含的芯片识别信息在出厂时编写,不可更改,使用指针读指定地址下的存储器可获取电子签名(STM32的ID号)

  • 闪存容量寄存器:

    • 基地址:0x1FFF F7E0

    • 大小:16位

  • 产品唯一身份标识寄存器:

    • 基地址: 0x1FFF F7E8

    • 大小:96位

八、读写内部FLASH

image-20250118151354221

Ⅰ、FLASH函数

/*------------ 所有STM32F10x设备通用的函数 -----*/
// 设置FLASH延迟
void FLASH_SetLatency(uint32_t FLASH_Latency);// 使能或失能半周期访问
void FLASH_HalfCycleAccessCmd(uint32_t FLASH_HalfCycleAccess);// 使能或失能预取指缓冲区
void FLASH_PrefetchBufferCmd(uint32_t FLASH_PrefetchBuffer);// 解锁FLASH
void FLASH_Unlock(void);
// 锁定FLASH
void FLASH_Lock(void);// 擦除指定页面
FLASH_Status FLASH_ErasePage(uint32_t Page_Address);
// 擦除所有页面
FLASH_Status FLASH_EraseAllPages(void);
// 擦除选项字节
FLASH_Status FLASH_EraseOptionBytes(void);// 编程一个字数据
FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data);
// 编程一个半字数据
FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data);
// 编程选项字节数据
FLASH_Status FLASH_ProgramOptionByteData(uint32_t Address, uint8_t Data);// 使能写保护
FLASH_Status FLASH_EnableWriteProtection(uint32_t FLASH_Pages);// 使能或失能读出保护
FLASH_Status FLASH_ReadOutProtection(FunctionalState NewState);// 配置用户选项字节
FLASH_Status FLASH_UserOptionByteConfig(uint16_t OB_IWDG, uint16_t OB_STOP, uint16_t OB_STDBY);
// 获取用户选项字节
uint32_t FLASH_GetUserOptionByte(void);
// 获取写保护选项字节
uint32_t FLASH_GetWriteProtectionOptionByte(void);// 获取读出保护状态
FlagStatus FLASH_GetReadOutProtectionStatus(void);// 获取预取指缓冲区状态
FlagStatus FLASH_GetPrefetchBufferStatus(void);// 配置FLASH中断
void FLASH_ITConfig(uint32_t FLASH_IT, FunctionalState NewState);// 获取FLASH标志位状态
FlagStatus FLASH_GetFlagStatus(uint32_t FLASH_FLAG);
// 清除FLASH标志位
void FLASH_ClearFlag(uint32_t FLASH_FLAG);// 获取FLASH状态
FLASH_Status FLASH_GetStatus(void);// 等待FLASH最后一次操作完成
FLASH_Status FLASH_WaitForLastOperation(uint32_t Timeout);/*------------ 所有STM32F10x设备新增的函数 -----*/
// 解锁FLASH Bank1
void FLASH_UnlockBank1(void);// 锁定FLASH Bank1
void FLASH_LockBank1(void);// 擦除FLASH Bank1所有页面
FLASH_Status FLASH_EraseAllBank1Pages(void);// 获取FLASH Bank1状态
FLASH_Status FLASH_GetBank1Status(void);// 等待FLASH Bank1最后一次操作完成
FLASH_Status FLASH_WaitForLastBank1Operation(uint32_t Timeout);#ifdef STM32F10X_XL//XL系列有两块FLASH:Bank1和Bank2
/*---- 仅适用于STM32F10x_XL容量设备的新增函数 -----*/
// 解锁FLASH Bank2
void FLASH_UnlockBank2(void);
// 锁定FLASH Bank2
void FLASH_LockBank2(void);// 擦除FLASH Bank2所有页面
FLASH_Status FLASH_EraseAllBank2Pages(void);// 获取FLASH Bank2状态
FLASH_Status FLASH_GetBank2Status(void);// 等待FLASH Bank2最后一次操作完成
FLASH_Status FLASH_WaitForLastBank2Operation(uint32_t Timeout);// 配置启动区
FLASH_Status FLASH_BootConfig(uint16_t FLASH_BOOT);
#endif

Ⅱ、使用示例:

MyFALSH.c
#include "stm32f10x.h"                  // Device header
//须在此实现>>读取、擦除、编程<<三个功能//读取***********************************************
//读取32位字
uint32_t MyFLASH_ReadWord(uint32_t Addr)
{	 return *((__IO uint32_t *)(Addr));;
}
//读取16位半字
uint16_t MyFLASH_ReadHalfWord(uint32_t Addr)
{	 return *((__IO uint16_t *)(Addr));;
}
//读取8位字节
uint8_t MyFLASH_ReadByte(uint32_t Addr)
{	 return *((__IO uint8_t *)(Addr));;
}//擦除***********************************************
//全擦除
void MyFLASH_EraseAllPages(void)
{FLASH_Unlock();//解锁FLASH_EraseAllPages();//全擦除FLASH_Lock();//上锁
}
//页擦除
void MyFLASH_ErasePage(uint32_t PageAddr)
{FLASH_Unlock();//解锁FLASH_ErasePage(PageAddr);//指定地址页擦除FLASH_Lock();//上锁
}//编程***********************************************
//编程一个字
void MyFLASH_ProgramWord(uint32_t Addr, uint32_t Data)
{FLASH_Unlock();//解锁FLASH_ProgramWord(Addr, Data);//编程一个字数据FLASH_Lock();//上锁
}
//编程一个半字
void MyFLASH_ProgramHalfWord(uint32_t Addr, uint16_t Data)
{FLASH_Unlock();//解锁FLASH_ProgramHalfWord(Addr, Data);//编程一个半字数据FLASH_Lock();//上锁	
}
MyFALSH.h
#ifndef __MYFLASH_H__
#define __MYFLASH_H__
#include "stdint.h"uint32_t MyFLASH_ReadWord(uint32_t Addr);		//读取32位字
uint16_t MyFLASH_ReadHalfWord(uint32_t Addr);	//读取16位半字
uint8_t MyFLASH_ReadByte(uint32_t Addr);		//读取8位字节
void MyFLASH_EraseAllPages(void);			//全擦除
void MyFLASH_ErasePage(uint32_t PageAddr);	//页擦除
void MyFLASH_ProgramWord(uint32_t Addr, uint32_t Data);		//编程一个字
void MyFLASH_ProgramHalfWord(uint32_t Addr, uint16_t Data);	//编程一个半字#endif
Store.c
#include "stm32f10x.h"                  // Device header
#include "MyFLASH.h"#define STORE_START_ADDR 0x0800FC00
#define STORE_COUNT 512//功能:将数据存储在闪存的最后一页(起始地址0x0800FC00)
uint16_t Store_Data[STORE_COUNT];//定义一个SRAM数组void Store_Init(void)
{if(MyFLASH_ReadHalfWord(STORE_START_ADDR) != 0x1234)//判断标志位{MyFLASH_ErasePage(STORE_START_ADDR);//擦除最后一页MyFLASH_ProgramHalfWord(STORE_START_ADDR, 0x1234);//置标志位//将SRAM数组中的内容放入这一页uint16_t i;for(i= 1; i < STORE_COUNT; i++)//由于第一个半字为标志位,故i从1开始{MyFLASH_ProgramHalfWord(STORE_START_ADDR + i * 2, 0x0000);//遍历写入0}}uint16_t i;for(i= 0; i < STORE_COUNT; i++)//读出数据放入数组中{Store_Data[i] = MyFLASH_ReadHalfWord(STORE_START_ADDR + i * 2);}
}//将数组中的数据保存到FLASH中
void Store_Save(void)
{MyFLASH_ErasePage(STORE_START_ADDR);//擦除FLASH的最后一页uint16_t i;for(i= 0; i < STORE_COUNT; i++)//SRAM数组中的数据写入FALSH中{MyFLASH_ProgramHalfWord(STORE_START_ADDR + i * 2, Store_Data[i]);}
}//清零
void Store_Clear(void)
{uint16_t i;for(i= 1; i < STORE_COUNT; i++)//由于第一个半字为标志位,故i从1开始{Store_Data[i] = 0x0000;}Store_Save();//保存更新
}
Store.h
#ifndef __STORE_H__
#define __STORE_H__
#include "stdint.h"extern uint16_t Store_Data[];//定义一个SRAM数组void Store_Init(void);
void Store_Save(void);//将数组中的数据保存到FLASH中
void Store_Clear(void);//清零#endif

九、读取设备ID

  • 闪存容量寄存器:

    • 基地址:0x1FFF F7E0

    • 大小:16位

  • 产品唯一身份标识寄存器:

    • 基地址: 0x1FFF F7E8

    • 大小:96位

image-20250118172336086

#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"int main(void)
{OLED_Init();OLED_ShowString(1,1,"F_Size:");OLED_ShowHexNum(1,8,*((__IO uint16_t *)(0x1FFFF7E0)),4);OLED_ShowString(2,1,"U_ID:");OLED_ShowHexNum(2,6,*((__IO uint16_t *)(0x1FFFF7E8)),4);OLED_ShowHexNum(2,11,*((__IO uint16_t *)(0x1FFFF7E8 + 0x02)),4);//加上地址偏移OLED_ShowHexNum(3,1,*((__IO uint32_t *)(0x1FFFF7E8 + 0x04)),8);OLED_ShowHexNum(4,1,*((__IO uint32_t *)(0x1FFFF7E8 + 0x08)),8);while(1){}
}

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

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

相关文章

CamemBERT:一款出色的法语语言模型

摘要 预训练语言模型在自然语言处理中已无处不在。尽管这些模型取得了成功&#xff0c;但大多数可用模型要么是在英语数据上训练的&#xff0c;要么是在多种语言数据拼接的基础上训练的。这使得这些模型在除英语以外的所有语言中的实际应用非常有限。本文探讨了为其他语言训练…

线性代数概述

矩阵与线性代数的关系 矩阵是线性代数的研究对象之一&#xff1a; 矩阵&#xff08;Matrix&#xff09;是一个按照长方阵列排列的复数或实数集合&#xff0c;是线性代数中的核心概念之一。矩阵的定义和性质构成了线性代数中矩阵理论的基础&#xff0c;而矩阵运算则简洁地表示和…

金仓Kingbase客户端KStudio报OOM:Java heap space socketTimeout

找到Kingbase\ES\V8\KESRealPro\V008R006C006B0021\ClientTools\guitools\KStudio\KStudio.ini 修改JVM参数&#xff1a; 默认值&#xff1a; -Xms512m -Xmx1024m 改为&#xff1a; -Xms1024m -Xmx2048m -XX:MaxPermSize512m SQL查询报错&#xff1a;An I/O error occurred …

Spring6.0新特性-HTTP接口:使用@HttpExchange实现更优雅的Http客户端

文章目录 一、概述二、使用1、创建接口HttpExchange方法2、创建一个在调用方法时执行请求的代理3、方法参数4、返回值5、错误处理&#xff08;1&#xff09;为RestClient&#xff08;2&#xff09;为WebClient&#xff08;3&#xff09;为RestTemplate 注意 一、概述 官方文档…

kubernetes学习-Service(七)

一、Service-pod-endpoint关系 # 查看endpoints [rootk8s-master deployments]# kubectl get endpoints NAME ENDPOINTS AGE kubernetes 192.168.129.136:6443 90m nginx-svc 10.109.131.1:80,10.111.156.65:80 22m # …

Python数据分析案例70——基于神经网络的时间序列预测(滞后性的效果,预测中存在的问题)

背景 这篇文章可以说是基于 现代的一些神经网络的方法去做时间序列预测的一个介绍科普&#xff0c;也可以说是一个各种模型对比的案例&#xff0c;但也会谈一谈自己做了这么久关于神经网络的时间序列预测的论文&#xff0c;其中一些常见的模式及它们存在的问题以及效果&#x…

opencv笔记2

图像灰度 彩色图像转化为灰度图像的过程是图像的灰度化处理。彩色图像中的每个像素的颜色由R&#xff0c;G&#xff0c;B三个分量决定&#xff0c;而每个分量中可取值0-255&#xff0c;这样一个像素点可以有256*256*256变化。而灰度图像是R&#xff0c;G&#xff0c;B三个分量…

LeetCode:2266. 统计打字方案数(DP Java)

目录 2266. 统计打字方案数 题目描述&#xff1a; 实现代码与解析&#xff1a; 动态规划 原理思路&#xff1a; 2266. 统计打字方案数 题目描述&#xff1a; Alice 在给 Bob 用手机打字。数字到字母的 对应 如下图所示。 为了 打出 一个字母&#xff0c;Alice 需要 按 对…

http://noi.openjudge.cn/——4.7算法之搜索——【169:The Buses】

题目 169:The Buses 总时间限制: 5000ms 内存限制: 65536kB 描述 A man arrives at a bus stop at 12:00. He remains there during 12:00-12:59. The bus stop is used by a number of bus routes. The man notes the times of arriving buses. The times when buses arrive …

java基础概念59-File

一、路径 二、File类 2-1、常见的构造方法 示例&#xff1a; 【注意】&#xff1a; 一般不自己用分割符把父路径和子路径拼接起来&#xff0c;因为&#xff0c;不用的操作系统&#xff0c;分隔符不同。 2-2、小结 2-3、File中常见的成员方法 示例&#xff1a; 【注意】&#…

PortSwigger靶场练习---第二关-查找和利用未使用的 API 端点

第二关&#xff1a;Finding and exploiting an unused API endpoint 实验&#xff1a;查找和利用未使用的 API 端点 PortSwigger靶场地址&#xff1a; Dashboard | Web Security Academy - PortSwigger 题目&#xff1a; 官方提示&#xff1a; 在 Burp 的浏览器中&#xff0c…

软路由系统iStoreOS 一键安装 docker compose

一键安装命令 大家好&#xff01;今天我来分享一个快速安装 docker-compose 的方法。以下是我常用的命令&#xff0c;当前版本是 V2.32.4。如果你需要最新版本&#xff0c;可以查看获取docker compose最新版本号 部分&#xff0c;获取最新版本号后替换命令中的版本号即可。 w…

SpringCloud nacos 2.0.0 + seata 2.0.0

NACOS 下载nacos https://github.com/alibaba/nacos/releases/tag/2.2.0 启动nacos startup.cmd -m standalone SEATA 下载seata https://seata.apache.org/release-history/seata-server 新建数据库-seata CREATE TABLE branch_table (branch_id bigint NOT NULL,xid …

springboot音乐播放器系统

Spring Boot音乐播放器系统是一个基于Spring Boot框架开发的音乐播放平台&#xff0c;旨在为用户提供高效、便捷的音乐播放体验。 一、系统背景与意义 随着互联网的飞速发展和人们对音乐娱乐需求的不断增长&#xff0c;音乐播放器已经成为人们日常生活中不可或缺的一部分。传…

奉加微PHY6230兼容性:部分手机不兼容

从事嵌入式单片机的工作算是符合我个人兴趣爱好的,当面对一个新的芯片我即想把芯片尽快搞懂完成项目赚钱,也想着能够把自己遇到的坑和注意事项记录下来,即方便自己后面查阅也可以分享给大家,这是一种冲动,但是这个或许并不是原厂希望的,尽管这样有可能会牺牲一些时间也有哪天原…

Go-知识 版本演进

Go-知识 版本演进 Go release notesr56(2011/03/16)r57(2011/05/03)Gofix 工具语言包工具小修订 r58(2011/06/29)语言包工具小修订 r59(2011/08/01)语言包工具 r60(2011/09/07)语言包工具 [go1 2012-03-28](https://golang.google.cn/doc/devel/release#go1)[go1.1 2013-05-13]…

C#,入门教程(02)—— Visual Studio 2022开发环境搭建图文教程

如果这是您阅读的本专栏的第一篇博文&#xff0c;建议先阅读如何安装Visual Studio 2022。 C#&#xff0c;入门教程(01)—— Visual Studio 2022 免费安装的详细图文与动画教程https://blog.csdn.net/beijinghorn/article/details/123350910 一、简单准备 开始学习、编写程序…

数字艺术类专业人才供需数据获取和分析研究

本文章所用数据集&#xff1a;数据集 本文章所用源代码&#xff1a;源代码和训练好的模型 第1章 绪论 1.1研究背景及意义 随着社会经济的迅速发展和科技的飞速进步&#xff0c;数字艺术类专业正逐渐崛起&#xff0c;并呈现出蓬勃发展的势头。数字艺术作为创作、设计和表现形式的…

imbinarize函数用法详解与示例

一、函数概述 众所周知&#xff0c;im2bw函数可以将灰度图像转换为二值图像。但MATLAB中还有一个imbinarize函数可以将灰度图像转换为二值图像。imbinarize函数是MATLAB图像处理工具箱中用于将灰度图像或体数据二值化的工具。它可以通过全局或自适应阈值方法将灰度图像转换为二…

使用ffmpeg提高mp4压缩比,减小文件体积【windows+ffmpeg+batch脚本】

文章目录 关于前情提要FFmpeg是什么使用脚本运行FFmpeg首先&#xff0c;下载ffmpeg.exe然后在视频相同位置写一个bat脚本运行压缩脚本 关于 个人博客&#xff0c;里面偶尔更新&#xff0c;最近比较忙。发一些总结的帖子和思考。 江湖有缘相见&#x1f91d;。如果读者想和我交…