while(1)
{
if(USART_RX_STA&0x8000) //如果接收结束
{
len=USART_RX_STA&0x3fff;//得到此次接收到的数据长度
printf("\r\n您发送的消息为:\r\n");
for(t=0;t<len;t++)
{
USART_SendData(USART1, USART_RX_BUF[t]); //向串口1发送数据
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET); //等待发送结束,这句必须有
}
printf("\r\n\r\n");//插入换行
USART_RX_STA=0;//传输完毕一串数据后 清零,不清零,串口就会一直重复向电脑发送数据
}else
{
times++;
if(times%200==0)
{
printf("请输入数据,以回车键结束\r\n");
if(times%200==0)LED1=!LED1;//闪烁LED,提示系统正在运行.
}
delay_ms(10); //每一个times+1后,延迟一下,要不然打印速度很快,延迟了200个10ms
}
}
利用重定向的printf函数向上位机发送语句“\r\n您发送的消息为:\r\n”,
语句显示的结果中语句末尾的“\r\n”并没有起到作用,即让光标移至下一行后再显示“逆光”。
修改方法:重定向的printf()函数本质上还是通过USART_SendData()向上位机发送数据
这种现象的原因是因为printf语句中的“\r\n”发送未完成,寄存器又被后面要发送的数据覆盖,解决方法就是将
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);
移动到前面,先判断之前的要发送的数据有没有发送出去,然后再调用
USART_SendData(USART1, USART_RX_BUF[t]);
for(t=0;t<len;t++)
{
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);//等待发送结束
USART_SendData(USART1, USART_RX_BUF[t]); //向串口1发送数据
}
这样就不会出现问题了,可以实现换行显示12345
版权声明:本文为ggbb_4原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。