找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1828|回復: 3
收起左側

STC89單片機串口計算器程序有BUG怎么解決?

[復制鏈接]
ID:466381 發(fā)表于 2020-12-6 00:45 | 顯示全部樓層 |閱讀模式
簡單來說就是做了個BUG很莫名其妙的串口計算器,我把輸出函數修改了一下用于找到程序的問題,結果發(fā)現(xiàn)被注釋掉的四行代碼都有問題,但是這四行代碼明明不可能會卡住啊,真的一臉懵逼。

單片機源程序如下:
  1. #include<reg52.h>
  2. #include<intrins.h>


  3. /*sjj
  4. 第五周普通任務2:
  5. 單片機計算器,保留兩位小數,電腦串口上顯示
  6. */

  7. #define u8 unsigned char
  8. #define u16 unsigned int
  9. u8 Huancun[16];//緩存,用于儲存一大堆的數據
  10. u8 DYGS[5];//第一個數的數組
  11. u8 DEGS[5];//第二個數的數組
  12. u8 ENDGO[5];//結果數組
  13. u8 Cal;//Cal為計算數值 1加2減3乘4除
  14. u8 lenths1,lenths2;//lenths1為第一個數的長度  lenths2為第二個數的長度
  15. u16 num1,num2;//兩個數的實際值
  16. u16 results;//計算結果
  17. u8 hymm;
  18. u8 lenths=0;
  19. bit flag=0;

  20. void Timer0Init();  //200us延時定時器1
  21. void Divide_Str();
  22. void Set_DYGS();
  23. void Set_DEGS();
  24. void Calculate();
  25. void Printg();
  26. void SendData(u8 dat);
  27. void UartInit(void);                //9600bps@11.0592MHz

  28. void main()
  29. {
  30.         Timer0Init();
  31.         UartInit();
  32.         while(1)
  33.         {
  34.                 if(flag)
  35.                 {
  36.                         flag=0;
  37.                         /*以下四行代碼只要有一個被解除注釋以后會出BUG,無法執(zhí)行接下來的程序,不明白怎么回事*/
  38.                         //Divide_Str();
  39.         //                Set_DYGS();
  40.                 //        Set_DEGS();
  41.                 //        Calculate();
  42.                         Printg();//發(fā)送結果到電腦串口上
  43.                 }
  44.         }
  45. }

  46. void Divide_Str()
  47. {
  48.         u8 i=0;
  49.         lenths1=0;
  50.         lenths2=0;
  51.         while(Huancun[i]!='+'||Huancun[i]!='-'||Huancun[i]!='*'||Huancun[i]!='/')
  52.         {
  53.                 DYGS[lenths1]=Huancun[i]-0x30;
  54.                 lenths1++;
  55.                 i++;
  56.         }
  57.         switch(Huancun[i])
  58.         {
  59.                 case '+':Cal=1;break;
  60.                 case '-':Cal=2;break;
  61.                 case '*':Cal=3;break;
  62.                 case '/':Cal=4;break;
  63.         }
  64.         i++;
  65.         while(Huancun[i]!= '=')
  66.         {
  67.                 DEGS[lenths2]=Huancun[i]-0x30;
  68.                 lenths2++;
  69.                 i++;
  70.         }
  71. }
  72.        
  73. void Set_DYGS()
  74. {
  75.         u16 linyuhan=1;
  76.         u8 i;
  77.         num1=0;
  78.         for(i=lenths1-1;i>=0;i--)
  79.         {
  80.                 num1+=linyuhan*DYGS[i];
  81.                 linyuhan*=10;
  82.         }
  83. }

  84. void Set_DEGS()
  85. {
  86.         u16 linyuhan=1;
  87.         u8 i;
  88.         num2=0;
  89.         for(i=lenths2-1;i>=0;i--)
  90.         {
  91.                 num2+=linyuhan*DEGS[i];
  92.                 linyuhan*=10;
  93.         }
  94. }

  95. void Calculate()
  96. {
  97.         switch(Cal)
  98.         {
  99.                 case 1:results=num1+num2;break;
  100.                 case 2:results=num1-num2;break;
  101.                 case 3:results=num1*num2;break;
  102.                 case 4:results=num1/num2;break;
  103.         }
  104. }

  105. void Printg()
  106. {
  107.         u8 i;
  108.         for(i=0;i<lenths;i++)
  109.         {
  110.                 SendData(Huancun[i]);
  111.         }
  112.         lenths=0;
  113. }

  114. void SendData(u8 dat)
  115. {
  116.     SBUF = dat;  //寫數據到UART數據寄存器
  117.                 while(TI==0);         //等待前面的數據發(fā)送完成
  118.                 TI = 0;
  119. }


  120. void UartInit(void)                //9600bps@11.0592MHz
  121. {
  122.         PCON &= 0x7F;                //波特率不倍速
  123.         SCON = 0x50;                //8位數據,可變波特率
  124.         TMOD &= 0x0F;                //清除定時器1模式位
  125.         TMOD |= 0x20;                //設定定時器1為8位自動重裝方式
  126.         TL1 = 0xFD;                //設定定時初值
  127.         TH1 = 0xFD;                //設定定時器重裝值
  128.         ET1 = 0;                //禁止定時器1中斷
  129.         TR1 = 1;                //啟動定時器1
  130.         ES=1;
  131.         EA=1;
  132. }

  133. void Timer0Init()  //200us延時定時器1
  134. {
  135.         TMOD &= 0xF0;                //設置定時器模式
  136.         TMOD |= 0x02;                //設置定時器模式
  137.         TL0 = 0x48;                //設置定時初值
  138.         TH0 = 0x48;                //設置定時重載值
  139.         TF0 = 0;                //清除TF0標志
  140.         TR0 = 0;                //定時器0開始計時       
  141.         ET0        =        1;
  142. }


  143. void Timer0() interrupt 1
  144. {
  145.         hymm++;
  146.         if(hymm==100)
  147.         {
  148.                 hymm=0;
  149.                 flag=1;
  150.                 TR0=0;
  151.         }
  152. }

  153. void Uart_Isr() interrupt 4
  154. {
  155.         if(RI)
  156.         {
  157.                 RI=0;
  158.                 TR0=1;
  159.                 hymm=0;
  160.                 Huancun[lenths++]=SBUF;
  161.         }
  162. }
復制代碼

所有資料51hei提供下載:
BUG程序.zip (36.57 KB, 下載次數: 9)

回復

使用道具 舉報

ID:584814 發(fā)表于 2020-12-7 21:21 | 顯示全部樓層
STC89單片機串口計算器程序有BUG怎么解決? debug
回復

使用道具 舉報

ID:863708 發(fā)表于 2020-12-25 23:25 | 顯示全部樓層
發(fā)現(xiàn)有幾個位置,循環(huán)出不來
1)while(Huancun[i]!='+'||Huancun[i]!='-'||Huancun[i]!='*'||Huancun[i]!='/')嘗試改為while(Huancun[i]!=0x2B)試了試;
2)void Set_DYGS()和void Set_DEGS()中i定義改為int i;
就能夠運行下去了。
回復

使用道具 舉報

ID:466381 發(fā)表于 2020-12-31 14:14 | 顯示全部樓層
awyy 發(fā)表于 2020-12-25 23:25
發(fā)現(xiàn)有幾個位置,循環(huán)出不來
1)while(Huancun!='+'||Huancun!='-'||Huancun!='*'||Huancun!='/')嘗試改為 ...

太感謝了
回復

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表