当前位置: 代码迷 >> 单片机 >> 小白~51单片机串口通信
  详细解决方案

小白~51单片机串口通信

热度:488   发布时间:2016-04-28 15:09:37.0
小白求助~~51单片机串口通信
通过串口收发单个字符是可以实现的,但一到字符串就不行了
就是如何让单片机接收一个字符串
以下是代码

#include<reg52.h>
#include"string.h"
#define uchar unsigned char
#define uint unsigned int

bit flag=0;
char aa[5],a,b[]="m1";
uchar k,m;

void init()
{
   TMOD=0x20;
   TH1=0xfd;
   TL1=0xfd;
   TR1=1;
   REN=1;
   SM0=0;
   SM1=1;
   EA=1;
   ES=1;
}

void main()
{
   init();
   for(k=0;k<5;k++)
  aa[k]='\0';
   while(1)
   {
      if(flag==1)
  {
     ES=0;
 if(strcmp(aa,b)==0)
 {
    P1=0xfe;
m=0;
for(k=0;k<5;k++)
   aa[k]='\0';
 }
 ES=1;
 flag=0;
  }
   }
}

void ser() interrupt 4
{
   if(RI)
   {
    a=SBUF;
RI=0;
aa[m]=a;
m++;
if(aa[m]=='\0'&&aa[m-1]!='\0')
   flag=1;
   }
   if(TI)
   {
        TI=0;
   }
}


哪里有问题啊

------解决方案--------------------
1.你把接收缓冲区初始化为全零,这样每收到一个字符,中断接收程序就会置标志位(当前字符为0,前一字符非0),所以你处理的永远是单字符的字符串。
2.\0是字符串结束标志,一般程序是不会发送这个字符的。所以接收程序不应该以此为字符串传送完标志。
3.可以自己定义一个结束符,比如'!','$',中断接收到结束符时再置标志位去比较字串
4.中断里别忘了加上边界检查,免得溢出缓冲区
------解决方案--------------------
interrupt 4{
        m++;
        //m = 1; aa[0] = a; aa[1] = '0'
        if(aa[m]=='\0'&&aa[m-1]!='\0')           
           flag=1;
}
------解决方案--------------------

只有收没有发呢

最好去计数一下,如果m>4则数组越界

其次, 语句 if(aa[m]=='\0'&&aa[m-1]!='\0') 应该可以省略吧 

还有你可以去找找串口会不会发送'\0'结束符
  相关解决方案