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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索

單片機串口發送寫好的數據,但用串口助手接收到的數據卻不一樣是怎么回事?

查看數: 6278 | 評論數: 11 | 收藏 0
關燈 | 提示:支持鍵盤翻頁<-左 右->
    組圖打開中,請稍候......
發布時間: 2020-12-28 14:08

正文摘要:

用串口發送數據,然后用串口助手接收數據,但接收到的數據和程序里寫的數據不一樣,請問這是怎么回事?串口發送的數據:uchar send[8]={0x01,0x03,0x00,0x00,0x00,0x02,0xC4,0x0B} 這是串口助手接收到的數據:跟程 ...

回復

ID:241128 發表于 2022-4-18 19:43
11樓說出了正解,鑒定完畢
ID:95703 發表于 2020-12-29 16:07
波特率不對吧
ID:866834 發表于 2020-12-29 10:42
仿真器一步一步調試啊
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:869964 發表于 2020-12-29 09:01
用仿真器一步一步調試,寄存器配置要按照單片機數據手冊配置好了才行
ID:168857 發表于 2020-12-29 08:56
直接找個例程移植啊,不要糾結這些小玩意
ID:814525 發表于 2020-12-29 08:43
把寄存器PCON修改為         PCON &= 0x7F;                //波特率不倍速
通常是不加倍的。
ID:796670 發表于 2020-12-29 08:10
wulin 發表于 2020-12-28 18:08
串口這點事學習一兩天就能搞定,你搞了一個多月還沒有搞定?測試串口功能只發不收不必開中斷。

謝謝老哥指點,謝謝指點,小弟我再回去好好想想
ID:867594 發表于 2020-12-28 22:51
老哥,串口助手點擊那個文本模式,hex模式看不懂的
ID:267719 發表于 2020-12-28 18:22
上位機偶校驗,那串口配置就要用方式2
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. }*/
復制代碼

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: www.中文字幕av | 91视频电影 | 国产一级片一区二区三区 | 一区二区三区四区不卡 | 国产毛片毛片 | 国产精品久久久久久久久免费相片 | 玖玖玖在线观看 | 日本精品视频 | 国产色片在线 | 天天爽夜夜爽精品视频婷婷 | 国产黄色大片 | 亚洲国产精品久久久久秋霞不卡 | 99re视频在线 | 夜夜艹| www.色综合 | 麻豆一区二区三区精品视频 | 久久久久久成人 | 99国产精品久久久 | 91精品国产乱码久久久久久久久 | 欧美日一区二区 | 综合久久综合久久 | 日韩一区av | 色本道| 久久av一区二区三区 | 国产免费自拍 | 日韩精品极品视频在线观看免费 | 久久精品一区二区视频 | 国产一区二区视频在线观看 | 超碰成人在线观看 | 亚洲毛片在线观看 | 国产日韩欧美中文字幕 | 亚洲综合色视频在线观看 | 日本不卡免费新一二三区 | 国产精品区一区二区三区 | 午夜精品视频 | 国产日韩欧美一区 | 天堂资源 | 婷婷综合| 国产精品1区2区3区 男女啪啪高潮无遮挡免费动态 | 女女爱爱视频 | 最新av在线播放 |