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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 242|回復: 5
打印 上一主題 下一主題
收起左側

stc8g單片機串口接收數據亂碼是為什么呢

[復制鏈接]
跳轉到指定樓層
樓主
單片機是stc8g1k08a,程序用的是一位大佬分享的,單片機直接和電腦usb連接,isp發送一個數據到單片機,就能接收到0-65536,但是接收到的是一樣的數據。頻率設置成30MHz,波特率是9600。是我哪里沒有設置好嗎,還是硬件這樣子連會有干擾呢



//使用STC-ISP軟件的串口助手顯示,波特率9600,需要自動發送一個字符。文本模式接收顯示 0~65535
typedef unsigned char         u8;
typedef unsigned short         u16;
u8 code ASCII[16]={"0123456789ABCDEF"};

#include "STC8.H"                                        //選擇頭文件,單片機STC8                                                                                 
                                       
#define FOSC 30000000UL                                /設置系統頻率,30M

u16 xdata Uart1_Byte[3]={0x5a9b,0xFFED,0x55};/需要打印的變量
bit Uart1_Flag=0;                                        /這個標志位寫1 就開始打印

//串口初始化,根據設計需要,波特率來源選擇:定時器1、定時器2、BRT獨立波特率,以下配置都是12分頻。
void Uart1_Init()
{               
        AUXR&=0xBF;                                                //定時器T1(16位自裝),STC15/STC8,定時器時鐘12T模式
        AUXR&=0xFE;                                                //定時器T1(16位自裝),STC15/STC8,串口1選擇定時器1為波特率發生器
        TMOD&=0x0F;                                                /定時器T1(16位自裝),STC15/STC8,設置定時器模式16位自動重裝
        TL1=(65536-FOSC/9600/4/12);                //定時器T1(16位自裝),STC15/STC8,設置定時初始值
        TH1=(65536-FOSC/9600/4/12)>>8;        //定時器T1(16位自裝),STC15/STC8,設置定時初始值
        ET1=0;                                                        //定時器T1(16位自裝),STC15/STC8,不需要定時器1的中斷
        TR1=1;//*/                                                //定時器T1(16位自裝),STC15/STC8,定時器1開始計時

        //以下代碼,這三行是必須的。
        SCON|=0x50;                                                //8位數據,可變波特率。
        ES = 1;                                                        //串口1中斷閘刀閉合,向CPU申請中斷。
        EA=1;                                                        //總中斷閘刀閉合導通。
}


//串口發送函數。主函數調用,或者串口發送完中斷后馬上調用
void Uart1_Up_Data_Drive()
{
        static u8 xdata count=0;
        if(Uart1_Flag)                                        //標志允許,發送一個字節
        {
                Uart1_Flag=0;                                //標志位翻轉,只允許發送一個字節
                count++;                                        //字節編號增加。
                switch(count)                                                                                                //打印成十六進制顯示
                {
                        case 1 : SBUF='\r';break;                                                                // 回車
                        case 2 : SBUF='\n';break;                                                                // 換行
                        case 3 : SBUF='0';break;                                                                // 0
                        case 4 : SBUF='x';break;                                                                // x         
                        case 5 : SBUF=ASCII[Uart1_Byte[0]/256/16];break;                //字節0
                        case 6 : SBUF=ASCII[Uart1_Byte[0]/256%16];break;                //字節0
                        case 7 : SBUF=ASCII[Uart1_Byte[0]%256/16];break;                //字節0
                        case 8 : SBUF=ASCII[Uart1_Byte[0]%256%16];break;                //字節0
                        case 9 : SBUF=' ';break;                                                                // 空格
                        
                        case 10 : SBUF='0';break;                                                                // 0
                        case 11 : SBUF='x';break;                                                                // x         
                        case 12 : SBUF=ASCII[Uart1_Byte[1]/256/16];break;                //字節1
                        case 13 : SBUF=ASCII[Uart1_Byte[1]/256%16];break;                //字節1
                        case 14 : SBUF=ASCII[Uart1_Byte[1]%256/16];break;                //字節1
                        case 15 : SBUF=ASCII[Uart1_Byte[1]%256%16];break;                //字節1
                        case 16 : SBUF=' ';break;                                                                // 空格
                        
                        case 17 : SBUF='0';break;                                                                // 0
                        case 18 : SBUF='x';break;                                                                // x         
                        case 19 : SBUF=ASCII[Uart1_Byte[2]/256/16];break;                //字節2
                        case 20 : SBUF=ASCII[Uart1_Byte[2]/256%16];break;                //字節2
                        case 21 : SBUF=ASCII[Uart1_Byte[2]%256/16];break;                //字節2
                        case 22 : SBUF=ASCII[Uart1_Byte[2]%256%16];break;                //字節2
                        case 23 :count=0;break;//最后一步 沒有發送字節,串口TI不會置1,所以不再發送
                }
        }
}
//串口中斷,接收一個字節,馬上發送N個字節,發送數組顯示到電腦
void Uart1_Routine() interrupt 4
{
        static char Uart1_ser_n=0;                //用于接收計數
        if(RI)                                                        //如果接收到一個字節
        {
                RI=0;                                                //標志位清除
                Uart1_Flag=1;                                //串口發送允許
                if(SBUF==0x7f)                                //最低波特率9600,最高波特率9600,判斷連續多個0x7f
                {
                        Uart1_ser_n++;                        //判斷連續多個0x7f
                        if(Uart1_ser_n>=10)                //判斷連續多個0x7f
                        {
                                Uart1_ser_n=0;                //清0
                                IAP_CONTR|=0xe0;        //執行自動軟復位,可以做調試用,STC12、STC15、STC8
                                //ISP_CONTR|=0xe0;        //執行自動軟復位,可以做調試用,STC89
                        }
                }
                else
                {
                        Uart1_ser_n=0;
                }
        }
        if(TI)                                                        //如果上一個字節發送完成了        
        {
                TI=0;                                                //標志位清除
                Uart1_Flag=1;                                //串口發送允許
                Uart1_Up_Data_Drive();                //執行串口發送下一個字節
        }
}

void Uart1_Allot()
{
        static u16 idata count;
        count++;
        if(count>50000)
        {
                count=0;
                Uart1_Flag=1;
        }
}

void main()
{
        Uart1_Init();
        while(1)
        {
                Uart1_Up_Data_Drive();
                Uart1_Allot();
        }
}
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:1109793 發表于 2025-4-16 16:51 | 只看該作者
我也用這個下載工具,但是為何我這里沒有顯示串口?
回復

使用道具 舉報

板凳
ID:624769 發表于 2025-4-16 18:04 | 只看該作者
哪里亂碼了? 看截圖,不是正確打印了么?

u16 xdata Uart1_Byte[3]={0x5a9b,0xFFED,0x55};/需要打印的變量
完全一樣不是么?
回復

使用道具 舉報

地板
ID:1076567 發表于 2025-4-17 09:18 | 只看該作者
xiaobendan001 發表于 2025-4-16 16:51
我也用這個下載工具,但是為何我這里沒有顯示串口?

是掃描串口沒顯示到嗎,這個下載工具一插到電腦上就會顯示出來,沒顯示的話你按手冊里制作USB-Link1D主控芯片的步驟試一下
回復

使用道具 舉報

5#
ID:1076567 發表于 2025-4-17 09:31 | 只看該作者
188610329 發表于 2025-4-16 18:04
哪里亂碼了? 看截圖,不是正確打印了么?

u16 xdata Uart1_Byte[3]={0x5a9b,0xFFED,0x55};/需要打印的變量 ...

嗷嗷是這樣的啊,那請問一下代碼中的0、x是什么呀,我看接收數據的時候都沒顯示出來,一直重復那行變量
回復

使用道具 舉報

6#
ID:1034262 發表于 2025-4-17 16:18 | 只看該作者
Dokkis 發表于 2025-4-17 09:31
嗷嗷是這樣的啊,那請問一下代碼中的0、x是什么呀,我看接收數據的時候都沒顯示出來,一直重復那行變量

編程最基本的知識也不具備?0x表示是十六進制數據
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 碰碰视频 | 在线观看成人精品 | 久久激情av | 精品国产久 | 欧美视频一区 | www.亚洲一区二区 | 日韩成人免费视频 | 亚洲一区二区在线视频 | 欧美日本亚洲 | 久久久久久久电影 | 国产成人91 | 午夜色婷婷 | 日本久久视频 | 国产精品毛片在线 | 亚洲午夜网 | 成人免费观看男女羞羞视频 | 超碰在线97国产 | 久久久精品一区 | 久久综合狠狠综合久久 | 日韩一区二区在线免费观看 | 国产精品久久久久久久久 | 欧美精品一区二区在线观看 | 欧美精品久久久久久 | 成人国产午夜在线观看 | 一区二区三区视频免费观看 | 九九九视频在线观看 | 亚洲国产精品久久人人爱 | 免费中文字幕 | 亚洲国产成人精品久久久国产成人一区 | 成人在线精品 | 欧洲亚洲一区二区三区 | 亚洲美女网站 | 天堂久久av | 国产一级视频 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 亚洲精品www| 免费黄色的视频 | 久久国产婷婷国产香蕉 | 亚洲免费av一区 | 成人伊人| 国产探花在线精品一区二区 |