久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6132|回復: 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 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品亚洲永久免费精品 | 国产综合视频 | 欧美视频二区 | 国产综合精品一区二区三区 | 欧美色图另类 | 日韩精品在线一区二区 | 精品美女久久久久久免费 | 伊人网站视频 | 色www精品视频在线观看 | 成人网视频 | 一区二区成人 | 欧美日韩中文字幕 | 国产精品欧美一区喷水 | 视频精品一区二区三区 | 欧美一区二区三区在线观看视频 | 爱爱免费视频 | 91欧美激情一区二区三区成人 | 久久久久久久久国产成人免费 | 国产亚洲成av人片在线观看桃 | a级片在线观看 | 国产亚洲精品一区二区三区 | 九九激情视频 | www.日韩 | 亚洲毛片在线观看 | 黄网免费| 九九精品在线 | 亚洲一区二区三区免费观看 | 精品网 | 伊人精品在线 | 99在线观看视频 | 超碰在线播 | 亚洲精品久久久久中文字幕欢迎你 | 四虎影视一区二区 | 成人a视频在线观看 | 在线2区 | 91精品国产91久久综合桃花 | 91不卡在线 | 午夜精品久久久久久久星辰影院 | 国产免费视频 | 亚洲成人一区 | 久久婷婷国产香蕉 |