单片机串口实验~不太懂这方面的代码希望有人能帮一下。
staticconstchar TestString[] = {"0123456789\r\n0123456789\r\n0123456789\r\n0123456789\r\n0123456789\r\n"};
浅答一下
1、static const char TestString[] = {"..."}定义了一串字符串,Duty是一个变量,用来控制PWM占空比。
2、要求输入d num可以设置Duty的值。其实提示中已经给出了思路,可以定义一个数组用来接收终端发过来的字符串。在接收中断中将接收到的内容存储起来。存储完成后在main函数中解析。比如第二条要求的输入d num设置占空比。可以在接收完数据之后检测接收内容中字符“d”之后的接收数字,然后将该数字赋值给Duty。
3、终端输入?回车,显示Duty的值,原理与2相同。接收完成后在main函数中解析,一旦收到?可以返回要求内容。
4、与3思路相同。
下面以stm32f103系列单片机为例给出关键部分大概的程序设计
1、串口接收中断服务函数
u32 receCount = 0; // 记录接收数据长度
u32 clearCount = 0; // 清空接收数组时for循环变量,需要声明到main
u8 receFifo[1500]; // 接收数组,需要声明到main
u8 receEndFlag = 0; // 接收完成标志,可以声明成为全局变量,在main函数中检测
// 串口接收中断服务函数
void USART1_IRQHandler(void)
{
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收到一个字节
{
receFifo[receCount++] = USART_ReceiveData(USART1);
}
else if(USART_GetITStatus(USART1,USART_IT_IDLE) != RESET) //接收到一帧数据
{
USART1->SR;//先读SR
USART1->DR;//再读DR
receEndFlag = 1; // 接收完成标志置1
}
}
2、接下来是main函数中的解析程序
extern u8 receEndFlag; // 声明接收完成标志位
extern u8 receFifo[1500]; // 声明接收数组
extern u32 clearCount; // 清空接收数组时for循环变量
if (receEndFlag == 1) // 如果接收完成
{
// 输入d num
if (receFifo[0] == 100) // 100是字符d的ASIIC码
{
// 此时读取d后面的数字值,组成一个变量赋值给Duty
}
// 输入?回车
if (receFifo[0] == 63) // 63是字符?的ASIIC码
{
// 此时返回要求的内容
}
// 输入t回车
if (receFifo[0] == 116) // 116是字符t的ASIIC码
{
// 此时返回要求的内容
}
// 清空接收数组
for (clearCount = 0;clearCount < receCount;clearCount ++)
{
receFifo[clearCount] = ' ';
}
receCount = 0; // 清零接收计数变量
receEndFlag = 0; // 清零接收完成标志位
}
ASIIC码对照表链接http://c.biancheng.net/c/ascii/
有帮助请采纳,谢谢!
题主也可以看一下这篇文章,可能会对你有帮助https://blog.csdn.net/qq_45217381/article/details/129443237?spm=1001.2014.3001.5501
这是一个用C语言编写的字符数组,可以被用于单片机的串口实验。
这个 char 类型的常量数组称之为 TestString,其中定义了一串字符,包括数字0到9,换行符(\r)和回车符(\n),其中每行都重复了五遍,总共输出了五行每行20个字符。需要注意的是,这个数组定义为常量,也就是不能修改其中的内容。
这个数组可以通过串口发送函数发送给其他设备,例如计算机或其他单片机,以进行串口通信测试。例如,使用以下方法将该字符串发送到串口:
char *p = TestString;
while(*p != '\0'){
send_byte(*p);
p++;
}
其中 send_byte 函数将一个字符发送到串口数据寄存器中,由串口硬件负责将数据发送到外设。