【蓝桥杯嵌入式】第十三届省赛(第二场)

目录

0 前言

1 展示

1.1 源码

1.2 演示视频

1.3 题目展示

2 CubeMX配置(第十三届省赛第二场真题)

2.1 设置下载线

2.2 HSE时钟设置

2.3 时钟树配置

2.4 生成代码设置

2.5 USART1

2.5.1 基本配置

2.5.2 NVIC

2.5.3 DMA 

2.6 TIM

2.6.1 TIM2

2.6.2 TIM4

2.6.3 TIM6

3 引脚配置

4 代码相关定义、声明

4.1 变量声明

4.2 函数声明

5 主要函数

5.1 LCD

5.2 KEY

5.3 EEPROM

5.4 LED

5.5 PWM

5.6 定时器回调函数

5.7 串口回调函数

 5.8 串口

5.9 上电初始化

6 测试

7 做题感受


菜狗上线~~~


0 前言

  • 开发板:CT117E-M4(STM32G431RBT6)
  • 软件环境:CubeMX + Keil5
  • 涉及题目:第十三届蓝桥杯嵌入式省赛第二场真题

1 展示

1.1 源码

Gitee链接:

1.2 演示视频

B站链接:

1.3 题目展示


2 CubeMX配置(第十三届省赛第二场真题)

2.1 设置下载线

2.2 HSE时钟设置

2.3 时钟树配置

晶振一定要改成24M,晶振一定要改成24M,晶振一定要改成24M,主频80M

2.4 生成代码设置

2.5 USART1

2.5.1 基本配置

题目要求串口1波特率9600

2.5.2 NVIC

串口一定要使能NVIC

2.5.3 DMA 

添加两个DMA即可

2.6 TIM

2.6.1 TIM2

TIM2用作PWM输出功能,通过引脚PA1输出

配置成2KHz的PWM

定时器2也要使能NVIC

2.6.2 TIM4

TIM4做基准定时器,10ms定时,专门用来按键扫描

预分频系数80-1

重装载值10000-1

定时器4也要使能NVIC

2.6.3 TIM6

定时器65用来实现倒计时5S,不开定时器6也可以用定时器4实现,这里我不想让倒计时和按键有联系,就多开了一个定时器,配置如下

定时器6也要使能NVIC


3 引脚配置

  • 配置8个LED         PD2  outpp    PC8~PC15   outpp
  • 配置4个按键         PA0、PB0、PB1、PB2    配置为上拉输入模式
  • 配置串口1            PA9  PA10
  • PWM                   PA1(TIM2-CH2)


4 代码相关定义、声明

4.1 变量声明

主要的变量定义如下所示,用了两个结构体,一个是写参数的,一个是写标志位的

/* 定义结构体 */
struct Param_TypeDef
{u32 LED_Tick; // LED定时 函数减速u32 LCD_Tick; // LCD定时 函数减速u32 RX_Tick;  // RX 定时 函数减速u32 PWM_Tick; // PWM定时 函数减速u32 EEP_Tick; // EEPROM 定时u8 LED_State; // LED状态变量u16 Set_PA1_Freq; //u8 Set_PA1_Duty;u8 Shop_Num_X; // 购买数量Xu8 Shop_Num_Y; // 购买数量Yfloat Price_X; // 单价Xfloat Price_Y; // 单价Yu8 REP_X;	   // 库存Xu8 REP_Y;	   // 库存Yfloat All_Price; // 总价u8 last_rep_X; // 上次的Xu8 last_rep_Y; // 上次的Yfloat Last_Price_X; // 单价Xfloat Last_Price_Y; // 单价Y
};struct Flag_TypeDef
{bool LCD_Dir;u8 LCD_View;		 // LCD界面u8 Current_Platform; // 当前平台bool Key4_Press;	 // KEY4按下bool led2_state;
};extern struct Param_TypeDef param;
extern struct Flag_TypeDef flag;/* 定义结构体 */// 定义状态机状态
#define SHOP 0
#define PRICE 1
#define REP 2

4.2 函数声明

/* 函数声明 */
void LED_proc(void);
void LCD_Disp_proc(void);
void Key_proc_Loop(void);
void Power_Init(void); // 上电初始化
void RX_Proc(void); // 串口接收函数
void PWM_Set_Proc(void);
void EEPROM_Proc(void);

5 主要函数

5.1 LCD

LCD一共有三个界面,分别是购买界面、单价界面、库存界面,分别题目要求到的标题和内容~

这里的MYLCD_printf()函数是我自己封装的

// LCD显示
void LCD_Disp_proc(void)
{// 函数减速if (uwTick - param.LCD_Tick < 50)return;param.LCD_Tick = uwTick;// 执行任务if (flag.LCD_View == SHOP){ // 购买界面MYLCD_printf(Line1, "        SHOP         ");MYLCD_printf(Line3, "     X:%2d           ", param.Shop_Num_X);MYLCD_printf(Line4, "     Y:%2d           ", param.Shop_Num_Y);}else if (flag.LCD_View == PRICE){ // 单价界面MYLCD_printf(Line1, "        PRICE        ");MYLCD_printf(Line3, "     X:%.1f           ", param.Price_X);MYLCD_printf(Line4, "     Y:%.1f           ", param.Price_Y);}else if (flag.LCD_View == REP){ // 库存界面MYLCD_printf(Line1, "        REP          ");MYLCD_printf(Line3, "     X:%2d           ", param.REP_X);MYLCD_printf(Line4, "     Y:%2d           ", param.REP_Y);}
}

正常的LCD显示语句,每次都要使用之前清零,再用sprint函数拼接字符串再调用LCD的显示函数,为了显示的更加简洁我用可变参数列表封装了这三行代码~代码如下

// // 使用之前先清除显示数组,再填写内容
// memset(LCD_Show_text, '\0', sizeof(LCD_Show_text));
// sprintf(LCD_Show_text, "    LED:OFF     ");
// LCD_DisplayStringLine(Line5, (uint8_t *)LCD_Show_text);
void MYLCD_printf(unsigned char linex, char *format, ...)
{char LCD_Show_text[30];memset(LCD_Show_text, '\0', sizeof(LCD_Show_text));va_list arg;                          // 定义可变参数列表数据类型的变量argva_start(arg, format);                // 从format开始,接收参数列表到arg变量vsprintf(LCD_Show_text, format, arg); // 使用vsprintf打印格式化字符串和参数列表到字符数组中LCD_DisplayStringLine(linex, (uint8_t *)LCD_Show_text);va_end(arg); // 结束变量arg//	sprintf((char *)LCD_Show_text, str);
}

思路如下: 

  1. //先清除数组的内容
  2. // 定义可变参数列表数据类型的变量arg
  3. // 从format开始,接收参数列表到arg变量
  4. // 使用vsprintf打印格式化字符串和参数列表到字符数组中
  5. //LCD显示
  6. // 结束变量arg

5.2 KEY

按键处理函数,使用01Stdio的按键扫描函数,放在定时器4里10ms扫描一次

按键1是切换界面

按键2是购买数量,注意越界回滚

按键3是购买单价,注意越界回滚,这个但是是浮点数,这里就有说到了,浮点数的2.0f其实不准确,如果判断当前价格>2.0了就参数回滚,会出现1.9直接跳变到2.0,所以我们把比较的数值改成2.01f就完美解决了~~~

按键4 计算总计,串口上传数据,发送完成,单价清零

void Key_proc_Loop(void)
{if (bkey[1].short_flag == 1){flag.LCD_View++;if (flag.LCD_View >= 3)flag.LCD_View = 0; // 三个界面bkey[1].short_flag = 0;}if (bkey[2].short_flag == 1){if (flag.LCD_View == SHOP){ // 购买界面param.Shop_Num_X++;if (param.Shop_Num_X > param.REP_X) // 超过库存,越界回滚成0param.Shop_Num_X = 0;}else if (flag.LCD_View == PRICE){ // 单价界面param.Price_X += 0.1f;if (param.Price_X > 2.01f) // 注意浮点数param.Price_X = 1.0f;  // 越界回滚}else if (flag.LCD_View == REP){ // 库存界面param.REP_X++;}bkey[2].short_flag = 0;}if (bkey[3].short_flag == 1) //{if (flag.LCD_View == SHOP){ // 购买界面param.Shop_Num_Y++;if (param.Shop_Num_Y > param.REP_Y) // 超过库存,越界回滚成0param.Shop_Num_Y = 0;}else if (flag.LCD_View == PRICE){ // 单价界面param.Price_Y += 0.1f;if (param.Price_Y > 2.01f) // 注意浮点数param.Price_Y = 1.0f;  // 越界回滚}else if (flag.LCD_View == REP){ // 库存界面param.REP_Y++;}bkey[3].short_flag = 0;}if (bkey[4].short_flag == 1) //{if (flag.LCD_View == SHOP){ // 购买界面flag.Key4_Press = 1;param.REP_X -= param.Shop_Num_X;param.REP_Y -= param.Shop_Num_Y;param.All_Price = param.Shop_Num_X * param.Price_X + param.Shop_Num_Y * param.Price_Y;memset(USART_tx_string, '\0', sizeof(USART_tx_string)); // 变量清零sprintf(USART_tx_string, "X:%d,Y:%d,Z:%.1f", param.Shop_Num_X, param.Shop_Num_Y, param.All_Price);HAL_UART_Transmit_DMA(&huart1, (uint8_t *)USART_tx_string, strlen(USART_tx_string));// 发送完成,单价清零param.Shop_Num_X = 0;param.Shop_Num_Y = 0;}bkey[4].short_flag = 0;}
}

5.3 EEPROM

这个函数100ms调用一次,在函数里判断当前值和100ms以前的值是否相等,如果不相等,就说明数据变化了,就需要存储到EEPROM中,存到对应的地址里

要存储的单价是一位浮点数,乘以10变成整数存进去,读取的时候不要忘记除以10即可

这里的逻辑是先判断,后赋值,如果先赋值后判断,永远检测不出来数据跳变,这里要细细品味一下,有之前写的按键扫描的味道~

void EEPROM_Proc(void)
{if (uwTick - param.EEP_Tick < 100)return;param.EEP_Tick = uwTick;if (param.last_rep_X != param.REP_X){EEPROM_WriteByte(0, param.REP_X); // 剩余数量XHAL_Delay(10);}if (param.last_rep_Y != param.REP_Y){EEPROM_WriteByte(1, param.REP_Y); // 剩余数量YHAL_Delay(10);}if (param.Last_Price_X != param.Price_X){EEPROM_WriteByte(2, (param.Price_X * 10)); // 单价XHAL_Delay(10);}if (param.Last_Price_Y != param.Price_Y){EEPROM_WriteByte(3, (param.Price_Y * 10)); // 单价YHAL_Delay(10);}param.last_rep_X = param.REP_X;param.last_rep_Y = param.REP_Y;param.Last_Price_X = param.Price_X;param.Last_Price_Y = param.Price_Y; // 延迟赋值
}

5.4 LED

LED显示函数,只需要写一次即可,我们只需要修改param.LED_State这个变量,就能达到控制哪一位LED亮灭的状态

LED显示多用位运算,非常巧妙~

//LED驱动函数
void LED_Disp(unsigned char state)
{HAL_GPIO_WritePin(GPIOC, 0xFF00, GPIO_PIN_SET);		  // 先全部熄灭 1HAL_GPIO_WritePin(GPIOC, state << 8, GPIO_PIN_RESET); // 点亮 0HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIN_SET);	  // 锁存器置高,使能HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIN_RESET); // 锁存器置低,失能
}
// LED处理函数
void LED_proc(void)
{static u8 led1, led2;// 函数减速if (uwTick - param.LED_Tick < 20)return;param.LED_Tick = uwTick;led1 = flag.Key4_Press << 0; // 5S内是1led2 = flag.led2_state << 1;param.LED_State = led1 | led2;LED_Disp(param.LED_State);
}

5.5 PWM

  • 设置频率,设置占空比,只修改变量即可
  • __HAL_TIM_SetAutoreload设置重装载值,80分频之后是1MHz = 1e6,用1e6/要设置的频率就是重装载值
  • __HAL_TIM_SetCompare设置比较值,设置高电平时间,即设置占空比,比较值=重装载值*占空比
void PWM_Set_Proc(void)
{if (uwTick - param.PWM_Tick < 100)return;param.PWM_Tick = uwTick;// 设置频率HAL_TIM_PWM_Start(&htim2, TIM_CHANNEL_2);param.Set_PA1_Freq = 2000;    //2000Hz__HAL_TIM_SetAutoreload(&htim2, 1e6 / param.Set_PA1_Freq - 1);// 设置占空比if (flag.Key4_Press == 1) // 5S内param.Set_PA1_Duty = 30;    //30%占空比elseparam.Set_PA1_Duty = 5;    //5%占空比__HAL_TIM_SetCompare(&htim2, TIM_CHANNEL_2, (1e6 / param.Set_PA1_Freq - 1) * param.Set_PA1_Duty / 100 + 1);    //设置占空比函数
}

5.6 定时器回调函数

定时器4专门用来10ms扫描一次按键

定时器6用来处理LED的5S点亮,和0.1S闪烁,使用标志位判断即可,这些都是常规操作~

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{static uint16_t LED_cnt, LED_cnt2;if (htim->Instance == TIM4){key_serv_double(); // 10ms按键处理}if (htim->Instance == TIM6) // 10ms进入一次 处理倒计时{if (flag.Key4_Press == 1){if (++LED_cnt >= 500){LED_cnt = 0;flag.Key4_Press = 0;}}if ((param.REP_X == 0) && (param.REP_Y == 0)) // 如果XY的库存都等于0{if (++LED_cnt2 >= 10){LED_cnt2 = 0; // 100msflag.led2_state = !flag.led2_state;}}elseflag.led2_state = 0;}
}

5.7 串口回调函数

// 串口的接收 回调函数
char USART_tx_string[50];
char rxdata[100];
uint8_t RX_Str_Data;
unsigned char rx_pointer; // 自己定义的指针,判断接收到哪了void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{if (huart->Instance == USART1) // 如果是USART1{param.RX_Tick = uwTick;rxdata[rx_pointer++] = RX_Str_Data;				// 接收到的字符串存放在这里HAL_UART_Receive_DMA(&huart1, &RX_Str_Data, 1); // 最后这个参数只能写1}
}

 5.8 串口

void RX_Proc(void)
{if (uwTick - param.RX_Tick < 50)return;param.RX_Tick = uwTick;// 执行任务if (rx_pointer == 1 && rxdata[0] == '?') // 如果收到一个数据,并且是#{memset(USART_tx_string, '\0', sizeof(USART_tx_string)); // 变量清零sprintf(USART_tx_string, "X:%.1f,Y:%.1f", param.Price_X, param.Price_Y);HAL_UART_Transmit_DMA(&huart1, (uint8_t *)USART_tx_string, strlen(USART_tx_string));}else if (rx_pointer > 0){}rx_pointer = 0;						  // 指针归位memset(rxdata, '\0', sizeof(rxdata)); // 变量清零
}

5.9 上电初始化

  1. LCD初始化
  2. 按键初始化
  3. 定时器初始化
  4. PWM初始化
  5. 串口DMA发送初始化
  6. 串口DMA接收初始化
  7. 检测是否第一次上电,如果是第一次上电,就初始化库存和单价
// 上电初始化
void Power_Init(void)
{LED_Disp(0x00); // 关掉所有LEDLCD_Init(); // LCD初始化LCD_Clear(Black);LCD_SetBackColor(Black);LCD_SetTextColor(White);LCD_DrawLine(120, 0, 320, Horizontal);LCD_DrawLine(0, 160, 240, Vertical);HAL_Delay(150);LCD_Clear(Blue);LCD_DrawRect(70, 210, 100, 100);HAL_Delay(150);LCD_Clear(Blue);LCD_DrawCircle(120, 160, 50);HAL_Delay(150);LCD_Clear(Black);LCD_SetBackColor(Black);LCD_SetTextColor(White);KEY_GPIO_Init(); // 手动初始化,防止忘记配置CubeMX// 定时器初始化HAL_TIM_Base_Start_IT(&htim4);HAL_TIM_Base_Start_IT(&htim6); // 用于倒计时//	// PWM初始化HAL_TIM_PWM_Start(&htim2, TIM_CHANNEL_2); // 打开定时器2 通道2HAL_UART_Transmit_DMA(&huart1, (uint8_t *)USART_tx_string, strlen(USART_tx_string));HAL_UART_Receive_DMA(&huart1, &RX_Str_Data, 1); // IT改为DMA// 参数初始化if (EEPROM_ReadByte(111) != 11) // 第一次进入是不等于的{// 先执行这里的代码// 第一次就先初始化param.REP_X = 10; // 库存默认10param.REP_Y = 10; // 库存默认10param.Price_X = 1.0;param.Price_Y = 1.0f;EEPROM_WriteByte(111, 11); // 在111写111}else // 不是第一次上电{// 上电先读取EEPROMparam.REP_X = EEPROM_ReadByte(0);HAL_Delay(1);param.REP_Y = EEPROM_ReadByte(1);HAL_Delay(1);param.Price_X = EEPROM_ReadByte(2) / 10.0;HAL_Delay(1);param.Price_Y = EEPROM_ReadByte(3) / 10.0;HAL_Delay(1);}
}

6 测试

按键可以自行测试,这里我只展示串口部分的效果


7 做题感受

  • 注意浮点数的比较 2.0f与2.01f的区别,看上面5.2 KEY 按键3的解释
  • 串口收发不到数据,没使用rx_proc函数,然后重新配置了一下TX和RX的DMA就可以使用了
  • PWM没有输出,使用定时器2通道2,我写成了通道1,所以没有输出...
  • EEPROM存储的数据不能是小数;
  • 试题中比较难的部分是如何判定设备是否是第一次启动以及EEPROM连续读取需要一定的时间间隔
  • 总的来说,该试题还是比较简单的,就剩一些常见的解题模式框架,🚀🚀🚀!!!

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

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

相关文章

企业组网异地组网区别是什么?

在现代企业运营过程中&#xff0c;随着企业规模的不断扩大和业务的全球化趋势&#xff0c;企业内部不可避免地需要进行组网工作。在组网过程中&#xff0c;有时可能需要实现异地组网&#xff0c;以便连接位于不同地理位置的分支机构或远程办公室。本文将对企业组网和异地组网进…

如何在社交媒体中使用增强现实来提高客户参与度?

目录 1. 增强现实在社交媒体中的应用是如何发展的 2. 社交媒体营销和广告中的增强现实 3. 社交媒体上的增强现实滤镜和镜头 4. 社交媒体平台上的增强现实购物 5. 利用社交媒体的增强现实事件和品牌激活 6. 增强现实在社交媒体中的未来是什么 7. 社交媒体中的增强现实常见…

Java常用API_正则表达式_分组——捕获分组与非捕获分组介绍与练习

在正则表达式中&#xff0c;从左到右第一个左括号确定为第一组&#xff0c;继续往右看再有左括号它表示的组数就加一。我们可以在正则表达式中使用 \\组数 的方法表示第几组&#xff0c;如\\1表示第一组的内容。 1.捕获分组 捕获分组就是把这一组的数据捕获出来&#xff0c;后…

vscode 安装vim插件配置ctrl + c/v功能

搜索Vim插件 插件介绍部分有提示操作 首先安装该插件&#xff0c;然后按照下述步骤设置ctrl相关的快捷键&#xff0c;以便于脱离im快捷键而愉快的敲代码。 1.在“设置”搜索框内搜索vim.handleKeys&#xff0c;选择 Edit in settings.json 2. 设置ctrl-c,ctrl-v等快捷键置为fa…

【Java集合进阶】list常见的方法和五种遍历方式数据结构

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【python】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收藏…

会话控制 与 IMS基本概念

目录 1. 因特网和电信网的介绍 2. 7号信令的分层结构及其作用 3. 基本的呼叫过程(ISUP流程) 4. 多媒体通信中的会话的概念 5. 关于IMS 5.1 IMS介绍 5.2 IMS控制层中的主要网元&#xff08;主要分为两类&#xff09; 5.3 现在来了解呼叫会话控制功能这一类的网元 6. 总…

2024/4/1—力扣—BiNode

代码实现&#xff1a; /*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/void convertBiNode_pro(struct TreeNode *root, struct TreeNode **p) {if (root) {convertBiNode_pro(roo…

python修改抖动图facecolor和箱型图alpha

抖动图和箱型图在数据分析和可视化中具有重要的作用&#xff0c;可以帮助人们更好地理解数据的特征和变化趋势。当我们想使用Python绘制抖动图的时候&#xff0c;可以使用seaborn的库来绘制&#xff0c;但其自身的参数限制了我们更改facecolor&#xff0c;绘制箱型图使更改透明…

什么是MQ ?为什么用MQ?

什么是MQ&#xff1f; MQ(message queue)&#xff08;消息队列&#xff09;&#xff0c;从字面意思上看&#xff0c;本质是个队列&#xff0c;FIFO先入先出&#xff0c;只不过队列中存放的内容是message而已&#xff0c;还是一种跨进程的通信机制&#xff0c;用于上下游传递消息…

Dubbo 服务发现

Dubbo 服务发现 1、什么是服务发现 **服务发现&#xff08;Service discovery&#xff09;**是自动检测一个计算机网络内的设备及其提供的服务。 2、Dubbo 与 服务发现 Dubbo 提供的是一种 Client-Based 的服务发现机制&#xff0c;依赖第三方注册中心组件来协调服务发现过…

C++从入门到精通——this指针

this指针 前言一、this指针的引出问题 二、this指针的特性三、例题什么时候会出现编译报错什么时候会出现运行崩溃this指针存在哪里this指针可以为空吗 四、C语言和C实现Stack的对比C语言实现C实现 前言 this指针是一个特殊的指针&#xff0c;在C类的成员函数中使用。它指向调…

Java笔试总结

. /etc/resolv.conf的用途是 A 邮件服务的设置文件 B DHCP的设置文件 C DNS解析的设置文件 D 网络路由的设置文件 答案: C 能够PING通同网段的节点&#xff0c;但却如PING不通其他网段的所有节点的最可能的原因() A 本机网关设置错误 B 本机没有正确设置DNS C 对方运行的是不…

webpack环境配置分类结合vue使用

文件目录结构 按照目录结构创建好文件 控制台执行: npm install /config/webpack.common.jsconst path require(path) const {merge} require(webpack-merge) const {CleanWebpackPlugin} require(clean-webpack-plugin) const { VueLoaderPlugin } require(vue-loader); c…

第十二届蓝桥杯大赛软件赛省赛C/C++大学B组

第十二届蓝桥杯大赛软件赛省赛C/C 大学 B 组 文章目录 第十二届蓝桥杯大赛软件赛省赛C/C 大学 B 组1、空间2、卡片3、直线4、货物摆放5、路径6、时间显示7、砝码称重8、杨辉三角形9、双向排序10、括号序列 1、空间 1MB 1024KB 1KB 1024byte 1byte8bit // cout<<"2…

nodejs详细安装步骤和npm配置

1、Node.js简介 Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时。Node.js 使用高效、轻量级的事件驱动、非阻塞 I/O 模型。它的包生态系统&#xff0c;npm&#xff0c;是目前世界上最大的开源库生态系统。 2、下载Node.js 官方地址&#xff1a;https://nodejs.org/…

STM32CubeMX+MDK通过I2S接口进行音频输入输出(全双工读写一个DMA回调)

一、前言 目前有一个关于通过STM32F411CEUx的I2S总线接口控制SSS1700芯片进行音频输入输出的研究。 SSS1700 是具有片上振荡器的 3S 高度集成的USB音频控制器芯片 。 SSS1700 功能支持96 KHz 24 位采样率&#xff0c;带外部音频编解码器&#xff08;24 位/96KHz I2S 输入和输出…

RabbitMQ的交换机与队列

一、流程 首先先介绍一个简单的一个消息推送到接收的流程&#xff0c;提供一个简单的图 黄色的圈圈就是我们的消息推送服务&#xff0c;将消息推送到 中间方框里面也就是 rabbitMq的服务器&#xff0c;然后经过服务器里面的交换机、队列等各种关系&#xff08;后面会详细讲&am…

腾讯云4核8G服务器12M带宽646元1年零3个月,4C8G使用场景说明

腾讯云4核8G服务器多少钱&#xff1f;腾讯云4核8G轻量应用服务器12M带宽租用价格646元15个月&#xff0c;活动页面 txybk.com/go/txy 活动链接打开如下图所示&#xff1a; 腾讯云4核8G服务器优惠价格 这台4核8G服务器是轻量应用服务器&#xff0c;详细配置为&#xff1a;轻量4核…

【ARMv7-M】| 01——阅读笔记 | 简介|应用程序级编程和内存模型

系列文章目录 【ARMv7-M】| 01——阅读笔记 | 简介|应用程序级编程和内存模型 失败了也挺可爱&#xff0c;成功了就超帅。 文章目录 前言1、简介2、应用程序级编程模型2.1 编程模式和访问等级2.2 数据类型和运算操作2.3 寄存器和执行状态1.2.4 异常和中断1.2.5 浮点单元寄存器…

【JAVASE】带你了解面向对象三大特性之一(多态)

✅作者简介&#xff1a;大家好&#xff0c;我是橘橙黄又青&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;再无B&#xff5e;U&#xff5e;G-CSDN博客 1.多态 1.1 多态的概念 多态的概念&#xff1a;通俗来说&#…