找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4965|回复: 11
收起左侧

单片机串口发送写好的数据,但用串口助手接收到的数据却不一样是怎么回事?

  [复制链接]
ID:796670 发表于 2020-12-28 14:08 | 显示全部楼层 |阅读模式
用串口发送数据,然后用串口助手接收数据,但接收到的数据和程序里写的数据不一样,请问这是怎么回事?串口发送的数据:uchar send[8]={0x01,0x03,0x00,0x00,0x00,0x02,0xC4,0x0B}
这是串口助手接收到的数据:跟程序里的数据不一样,请问大家这是哪里错了啊?
捕获1.PNG

后来我又把发送的数据全部改成了0X00,结果如下 捕获2.PNG
结果接收到的是这个
捕获3.PNG


这是完整程序:
  1. #include <stc12c5a.h>
  2. #include <stdio.h>
  3. #include <string.h>
  4. #include <stdlib.h>
  5. #include <math.h>
  6. #include <intrins.h>
  7. #define uchar unsigned char
  8. #define uint  unsigned int

  9. uchar rec[9];//接收
  10. uchar send[8]={0x01,0x03,0x00,0x00,0x00,0x02,0xC4,0x0B};//发送数据
  11. uchar num=0;
  12. int i;
  13. void delay(uint z)//延时函数
  14. {
  15.         uint x,y;
  16.         for(x=z;x>0;x--);
  17.                 for(y=110;y>0;y--);
  18. }


  19. void init()  //系统初始化
  20. {
  21. TMOD |=0X20;//定时器T1,方式2,波特率由PCON寄存器的SMOD决定
  22. SCON=0x50; //REN RI TI,RI为0,TI为0
  23. //串行口1方式1 SCON是串行口1的串行控制寄存器,REN为1,允许接收
  24. PCON=0x00;//各工作方式波特率加倍
  25. TH1=0xfD;//9600bps@11.0592
  26. TL1=0xfD;
  27. TR1=1; //定时器1中断打开
  28. EA=1;//cpu总中断允许位,1为开放中断
  29. ES=1;// 1允许串行口中断
  30. }

  31. void main()
  32. {
  33.         uchar m=0;
  34.         init();
  35.   while(1)
  36.         {
  37.          EA=0;//关中断
  38.         
  39.          for(i=0;i<8;i++)
  40.                 {
  41.                   SBUF=send[i];//发送数据
  42.                         while(TI==0);
  43.       {
  44.                                          }                        //数据发送结束时TI自动置1
  45.                         TI=0;        
  46.                 }
  47.                 EA=1;//开中断
  48.                 delay(1000);        
  49.   }
  50. }

  51. void UART_1() interrupt 4
  52. {
  53.                 RI=0; //RI置0
  54.           rec[num]=SBUF;        
  55.         if(rec[0]==0x01)
  56.                 {
  57.        num++;
  58.                          if(num>=9)
  59.                          {
  60.                                  num=0;
  61.                          }
  62.                 }
  63. }
复制代码
回复

使用道具 举报

ID:213173 发表于 2020-12-28 18:08 | 显示全部楼层
串口这点事学习一两天就能搞定,你搞了一个多月还没有搞定?测试串口功能只发不收不必开中断。

  1. #include <stc12c5a.h>
  2. //#include <stdio.h>
  3. //#include <string.h>
  4. //#include <stdlib.h>
  5. //#include <math.h>
  6. //#include <intrins.h>
  7. #define uchar unsigned char
  8. #define uint  unsigned int

  9. uchar rec[9];//接收
  10. uchar send[8]={0x01,0x03,0x00,0x00,0x00,0x02,0xC4,0x0B};//发送数据
  11. uchar num=0;
  12. int i;
  13. void delay(uint z)//延时函数
  14. {
  15.         uint x,y;
  16.         for(x=z;x>0;x--);
  17.                 for(y=110;y>0;y--);
  18. }


  19. void init()  //系统初始化
  20. {
  21. TMOD|=0X20;//定时器T1,方式2,波特率由PCON寄存器的SMOD决定
  22. SCON=0x50; //REN RI TI,RI为0,TI为0
  23. //串行口1方式1 SCON是串行口1的串行控制寄存器,REN为1,允许接收
  24. PCON=0x00;//各工作方式波特率加倍
  25. TH1=0xfD;//9600bps@11.0592
  26. TL1=0xfD;
  27. TR1=1; //定时器1中断打开
  28. // EA=1;//cpu总中断允许位,1为开放中断
  29. // ES=1;// 1允许串行口中断
  30. }

  31. void main()
  32. {
  33. //        uchar m=0;
  34.         init();
  35.         while(1)
  36.         {
  37.                 EA=0;//关中断       
  38.                 for(i=0;i<8;i++)
  39.                 {
  40.                         SBUF=send[i];//发送数据
  41.                         while(TI==0);//数据发送结束时TI自动置1                       
  42.                         TI=0;        
  43.                 }
  44.                 EA=1;//开中断
  45.                 delay(1000);        
  46.         }
  47. }
  48. /*       
  49. void UART_1() interrupt 4
  50. {
  51.         RI=0; //RI置0
  52.         rec[num]=SBUF;        
  53.         if(rec[0]==0x01)
  54.         {
  55.                 num++;
  56.                 if(num>=9)
  57.                 {
  58.                         num=0;
  59.                 }
  60.         }
  61. }*/
复制代码
回复

使用道具 举报

ID:267719 发表于 2020-12-28 18:22 | 显示全部楼层
上位机偶校验,那串口配置就要用方式2
回复

使用道具 举报

ID:867594 发表于 2020-12-28 22:51 | 显示全部楼层
老哥,串口助手点击那个文本模式,hex模式看不懂的
回复

使用道具 举报

ID:796670 发表于 2020-12-29 08:10 | 显示全部楼层
wulin 发表于 2020-12-28 18:08
串口这点事学习一两天就能搞定,你搞了一个多月还没有搞定?测试串口功能只发不收不必开中断。

谢谢老哥指点,谢谢指点,小弟我再回去好好想想
回复

使用道具 举报

ID:814525 发表于 2020-12-29 08:43 | 显示全部楼层
把寄存器PCON修改为         PCON &= 0x7F;                //波特率不倍速
通常是不加倍的。
回复

使用道具 举报

ID:168857 发表于 2020-12-29 08:56 | 显示全部楼层
直接找个例程移植啊,不要纠结这些小玩意
回复

使用道具 举报

ID:869964 发表于 2020-12-29 09:01 | 显示全部楼层
用仿真器一步一步调试,寄存器配置要按照单片机数据手册配置好了才行
回复

使用道具 举报

ID:390416 发表于 2020-12-29 09:51 | 显示全部楼层
#include "all.h"
bit Uart1_Flag=1;
u8 code Uart1_Up_Symbol_Buffer[30]={"\r\n温度:  遥控解码:  超声波:mm"};
u8 xdata Uart1_Up_Num_Buffer[10];
void Uart1_Init()
{
        SM0=0;
        SM1=1;
        REN=1;
        //SCON|=0x50;
       
        PCON&=0x3f;
        AUXR|=0x01;
        AUXR|=0X14;
        T2H=0xfc;
        T2L=0xf3;
        ES=1;
}


void Uart1_Up_Data_Drive()
{
        static u8 xdata count=0;
        if(Uart1_Flag)
        {
                Uart1_Flag=0;
                count++;
                switch(count)
                {
                        case 1 : SBUF=Uart1_Up_Symbol_Buffer[0];break;
                        case 2 : SBUF=Uart1_Up_Symbol_Buffer[1];break;
                        case 3 : SBUF=Uart1_Up_Symbol_Buffer[2];break;
                        case 4 : SBUF=Uart1_Up_Symbol_Buffer[3];break;
                        case 5 : SBUF=Uart1_Up_Symbol_Buffer[4];break;
                        case 6 : SBUF=Uart1_Up_Symbol_Buffer[5];break;
                        case 7 : SBUF=Uart1_Up_Symbol_Buffer[6];break;
                        case 8 : SBUF=Uart1_Up_Num_Buffer[0];break;
                        case 9 : SBUF=Uart1_Up_Num_Buffer[1];break;
                        case 10 :SBUF=Uart1_Up_Num_Buffer[2];break;
                        case 11 :SBUF=Uart1_Up_Num_Buffer[3];break;
                       
                        case 12 : SBUF=Uart1_Up_Symbol_Buffer[7];break;
                        case 13 : SBUF=Uart1_Up_Symbol_Buffer[8];break;
                        case 14 : SBUF=Uart1_Up_Symbol_Buffer[9];break;
                        case 15 : SBUF=Uart1_Up_Symbol_Buffer[10];break;
                        case 16 : SBUF=Uart1_Up_Symbol_Buffer[11];break;
                        case 17 : SBUF=Uart1_Up_Symbol_Buffer[12];break;
                        case 18 : SBUF=Uart1_Up_Symbol_Buffer[13];break;
                        case 19 : SBUF=Uart1_Up_Symbol_Buffer[14];break;
                        case 20 : SBUF=Uart1_Up_Symbol_Buffer[15];break;
                        case 21 : SBUF=Uart1_Up_Symbol_Buffer[16];break;
                        case 22 : SBUF=Uart1_Up_Symbol_Buffer[17];break;
                        case 23 : SBUF=Uart1_Up_Num_Buffer[5];break;
                        case 24 : SBUF=Uart1_Up_Num_Buffer[6];break;
                       
                        case 25 : SBUF=Uart1_Up_Symbol_Buffer[18];break;
                        case 26 : SBUF=Uart1_Up_Symbol_Buffer[19];break;
                        case 27 : SBUF=Uart1_Up_Symbol_Buffer[20];break;
                        case 28 : SBUF=Uart1_Up_Symbol_Buffer[21];break;
                        case 29 : SBUF=Uart1_Up_Symbol_Buffer[22];break;
                        case 30 : SBUF=Uart1_Up_Symbol_Buffer[23];break;
                        case 31 : SBUF=Uart1_Up_Symbol_Buffer[24];break;
                        case 32 : SBUF=Uart1_Up_Symbol_Buffer[25];break;
                        case 33 : SBUF=Uart1_Up_Symbol_Buffer[26];break;
                        case 34 : SBUF=Uart1_Up_Num_Buffer[7];break;
                        case 35 : SBUF=Uart1_Up_Num_Buffer[8];break;
                        case 36 : SBUF=Uart1_Up_Num_Buffer[9];break;
                        case 37 : SBUF=Uart1_Up_Symbol_Buffer[27];break;
                        case 38 : SBUF=Uart1_Up_Symbol_Buffer[28];break;
                        case 39 :count=0;break;
                }
        }
}

void Uart1_Routine() interrupt 4
{
        static char Uart1_ser_n=0;
        if(RI)
        {
                RI=0;
                Uart1_Flag=1;
                if(SBUF==0x7f)//9600波特率
                {
                        Uart1_ser_n++;
                        if(Uart1_ser_n>=10)
                        {
                                Uart1_ser_n=0;
                                IAP_CONTR|=0xe0;
                        }
                }
        }
        if(TI)
        {
                TI=0;
                Uart1_Flag=1;
                Uart1_Up_Data_Drive();
        }
}

一、以上代码是STC15W的,可能需要修改定时器参数。
二、主函数while大循环前面初始化IO口和Uart1_Init();
三、主函数每间隔大约500ms 执行一次Uart1_Up_Data_Drive();这个函数,确保数据能够发送。
四、串口通信,电脑发送一个字节。才能让单片机发送。
五、接收端波特率要正确,文本模式接收才能显示汉字。
六、以上代码由《人人学会单片机》视频教程原创,也就是我本人原创,引用请备注代码出处。
回复

使用道具 举报

ID:866834 发表于 2020-12-29 10:42 | 显示全部楼层
仿真器一步一步调试啊
回复

使用道具 举报

ID:95703 发表于 2020-12-29 16:07 | 显示全部楼层
波特率不对吧
回复

使用道具 举报

ID:241128 发表于 2022-4-18 19:43 | 显示全部楼层
11楼说出了正解,鉴定完毕
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表