stm32串口接收字符串代码
时间: 2023-07-27 21:07:28 浏览: 96
以下是一个基于STM32的串口接收字符串的示例代码:
```c++
#include "stm32f4xx.h"
#include <stdio.h>
#include <string.h>
#define RX_BUF_SIZE 64
uint8_t rx_buf[RX_BUF_SIZE];
uint8_t rx_data;
uint8_t rx_index = 0;
uint8_t rx_complete_flag = 0;
void USART1_IRQHandler(void) {
if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) {
rx_data = USART_ReceiveData(USART1);
if (rx_data == '\n') {
rx_buf[rx_index] = '\0';
rx_index = 0;
rx_complete_flag = 1;
} else {
rx_buf[rx_index++] = rx_data;
}
}
}
int main(void) {
USART_InitTypeDef USART_InitStruct;
// 初始化USART1
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
USART_InitStruct.USART_BaudRate = 115200;
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(USART1, &USART_InitStruct);
USART_Cmd(USART1, ENABLE);
// 初始化NVIC
NVIC_InitTypeDef NVIC_InitStruct;
NVIC_InitStruct.NVIC_IRQChannel = USART1_IRQn;
NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;
NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0;
NVIC_Init(&NVIC_InitStruct);
// 启用USART1的接收中断
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
while (1) {
if (rx_complete_flag) {
printf("Received string: %s\r\n", rx_buf);
rx_complete_flag = 0;
}
}
}
```
在代码中,我们定义了一个 `rx_buf` 数组来存储接收到的字符串,使用 `rx_data` 变量来暂存每次接收到的字节,使用 `rx_index` 变量来追踪 `rx_buf` 数组的当前索引。当接收到 `\n` 字符时,我们将 `rx_buf` 数组中的当前字符串结束符设置为 `\0`,表示字符串接收完毕,并将 `rx_complete_flag` 标志位置为 1,以便在主循环中处理接收到的字符串。
在 `USART1_IRQHandler` 函数中,我们检查是否有新的字节到达,并将其存储到 `rx_data` 变量中。如果接收到的字节是 `\n`,我们将 `rx_buf` 数组中的当前字符串结束符设置为 `\0`,并将 `rx_complete_flag` 标志位置为 1。否则,我们将接收到的字节存储到 `rx_buf` 数组中,并将 `rx_index` 变量加一。
在主循环中,我们检查 `rx_complete_flag` 标志位是否被设置。如果被设置,我们打印接收到的字符串,并将 `rx_complete_flag` 标志位清零,以便下一次接收。
阅读全文