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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

如何提取51單片機串口接收的數據并轉整型?

[復制鏈接]
跳轉到指定樓層
樓主
ID:328334 發表于 2019-3-23 22:13 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
180黑幣
我希望把51單片機串口接收的數據,分別提取后兩位,倒數第三第四位,并轉換成整形

單片機程序如下:
  1. #include "reg52.h"
  2. #include "stdio.h"
  3. #include "string.h"
  4. #define uchar unsigned char
  5. #define uint unsigned int
  6. void send_byte(uchar by);
  7. void send_string(uchar *p);
  8. void delay(uint n);        

  9. uchar rst[]="AT+RST\r\n";
  10. uchar mod[]="AT+CWMODE=3\r\n";
  11. uchar wico[]="AT+CWJAP=\"Nick\",\"qweasdzxc\"\r\n";
  12. uchar sev[]="AT+CIPSTART=\"TCP\",\"192.168.43.31\",8080\r\n";
  13. uchar mods[]="AT+CIPMODE=1\r\n";
  14. uchar sen[]="AT+CIPSEND\r\n";
  15. uchar in[]="in\r\n";
  16. uchar copa[]="bye\r\n";

  17. uint g,y,r;
  18. sbit ght=P2^0;
  19. sbit yht=P2^1;
  20. sbit rht=P2^2;
  21. void UsartInit()
  22. {
  23.                 SCON=0X50;               
  24.                 T2CON=0X34;            
  25.                 PCON=0X80;               
  26.                 RCAP2H=(65536-39)/256;               
  27.     RCAP2L=(65536-39)%256;
  28.     ES=0;                                
  29.     EA=1;
  30.                 ET0=1;
  31.                 ET1=1;
  32.                 EX0=1;
  33.                 IT0=1;
  34.                 EX1=1;
  35.                 IT1=1;
  36. }

  37. void main()
  38. {
  39.         
  40.         UsartInit();
  41.         send_string(rst);
  42.         delay(1);
  43.         send_string(mod);
  44.         delay(1);
  45.         send_string(wico);
  46.         delay(10);
  47.         send_string(sev);
  48.         delay(10);
  49.         send_string(mods);
  50.         delay(5);
  51.         send_string(sen);
  52.         delay(3);
  53.         ES=1;
  54.         g=5;
  55.         y=2;
  56.         r=5;
  57.         while(1)
  58.         {
  59.                 ght=0;
  60.                 yht=1;
  61.                 rht=1;
  62.                 delay(g);
  63.                 ght=1;
  64.                 yht=0;
  65.                 rht=1;
  66.                 delay(y);
  67.                 ght=1;
  68.                 yht=1;
  69.                 rht=0;
  70.                 delay(r);
  71.         }
  72. }        


  73. void send_byte(uchar by)
  74. {
  75.                 SBUF = by;
  76.     while(!TI);
  77.     TI = 0;      
  78. }

  79. void send_string(uchar *p)
  80. {
  81.     while(*p!= '\0')
  82.                         {
  83.         send_byte(*p);
  84.         p++;
  85.     }
  86. }


  87. void delay(uint n)
  88. {
  89.         unsigned int i=0;
  90.   for(i=0;i<n;i++)
  91.         {
  92.                 #pragma asm
  93.                 DEL3:MOV R0,#100
  94.                 DEL2:MOV R1,#100
  95.                 DEL1:MOV R2,#25
  96.           DEL0:NOP
  97.                NOP
  98.                DJNZ R2,DEL0
  99.                DJNZ R1,DEL1
  100.                DJNZ R0,DEL2
  101.         #pragma endasm
  102.         }                                
  103. }
  104. void Usart() interrupt 4
  105. {
  106.         
  107.         uchar str1;
  108. #include "reg52.h"
  109. #include "stdio.h"
  110. #include "string.h"
  111. #define uchar unsigned char
  112. #define uint unsigned int
  113. void send_byte(uchar by);
  114. void send_string(uchar *p);
  115. void delay(uint n);        

  116. uchar rst[]="AT+RST\r\n";
  117. uchar mod[]="AT+CWMODE=3\r\n";
  118. uchar wico[]="AT+CWJAP=\"Nick\",\"qweasdzxc\"\r\n";
  119. uchar sev[]="AT+CIPSTART=\"TCP\",\"192.168.43.31\",8080\r\n";
  120. uchar mods[]="AT+CIPMODE=1\r\n";
  121. uchar sen[]="AT+CIPSEND\r\n";
  122. uchar in[]="in\r\n";
  123. uchar copa[]="bye\r\n";

  124. uint g,y,r;
  125. sbit ght=P2^0;
  126. sbit yht=P2^1;
  127. sbit rht=P2^2;
  128. void UsartInit()
  129. {
  130.                 SCON=0X50;               
  131.                 T2CON=0X34;            
  132.                 PCON=0X80;               
  133.                 RCAP2H=(65536-39)/256;               
  134.     RCAP2L=(65536-39)%256;
  135.     ES=0;                                
  136.     EA=1;
  137.                 ET0=1;
  138.                 ET1=1;
  139.                 EX0=1;
  140.                 IT0=1;
  141.                 EX1=1;
  142.                 IT1=1;
  143. }

  144. void main()
  145. {
  146.         
  147.         UsartInit();
  148.         send_string(rst);
  149.         delay(1);
  150.         send_string(mod);
  151.         delay(1);
  152.         send_string(wico);
  153.         delay(10);
  154.         send_string(sev);
  155.         delay(10);
  156.         send_string(mods);
  157.         delay(5);
  158.         send_string(sen);
  159.         delay(3);
  160.         ES=1;
  161.         g=5;
  162.         y=2;
  163.         r=5;
  164.         while(1)
  165.         {
  166.                 ght=0;
  167.                 yht=1;
  168.                 rht=1;
  169.                 delay(g);
  170.                 ght=1;
  171.                 yht=0;
  172.                 rht=1;
  173.                 delay(y);
  174.                 ght=1;
  175.                 yht=1;
  176.                 rht=0;
  177.                 delay(r);
  178.         }
  179. }        


  180. void send_byte(uchar by)
  181. {
  182.                 SBUF = by;
  183.     while(!TI);
  184.     TI = 0;      
  185. }

  186. void send_string(uchar *p)
  187. {
  188.     while(*p!= '\0')
  189.                         {
  190.         send_byte(*p);
  191.         p++;
  192.     }
  193. }


  194. void delay(uint n)
  195. {
  196.         unsigned int i=0;
  197.   for(i=0;i<n;i++)
  198.         {
  199.                 #pragma asm
  200.                 DEL3:MOV R0,#100
  201.                 DEL2:MOV R1,#100
  202.                 DEL1:MOV R2,#25
  203.           DEL0:NOP
  204.                NOP
  205.                DJNZ R2,DEL0
  206.                DJNZ R1,DEL1
  207.                DJNZ R0,DEL2
  208.         #pragma endasm
  209.         }
  210. }
  211. void Usart() interrupt 4
  212. {
  213.         
  214.         uchar str;
  215.         str=SBUF;
  216.         RI = 0;//
  217. }
  218. void Iny0()        interrupt 0        
  219. {
  220.         ES=0;
  221.         send_string(in);
  222.         ES=1;
  223. }
  224. void Iny1()        interrupt 2
  225. {
  226.         ES=0;
  227.         send_string(copa);
  228.         ES=1;
  229. }
  230.         str1=SBUF;

  231.         RI = 0;//
  232. }                                       
  233. void Iny0()        interrupt 0        
  234. {
  235.         ES=0;
  236.         send_string(in);
  237.         ES=1;
  238. }
  239. void Iny1()        interrupt 2
  240. {
  241.         ES=0;
  242.         send_string(copa);
  243.         ES=1;
  244. }
復制代碼


最佳答案

查看完整內容

想像一下:一個數據流從你面前流過,你如何知道誰是最后一個呢? 無法確定最后一個是誰,又何來倒數呢? 問題的前鍵就是這個! 也即通訊協議是如何定義:結束標記的! 你先規劃一個緩沖區,大小=4個字節+結束標記。每次收到數據就依序放入這個區域(循環放置,并設置一個指針PX,每次輸入使PX指向它,目的:可以知道何處是頭,何處是尾。)每次輸入后,在PX(注意是循環+,要保證不溢出)的地方,判一下是不是結束標記,如何是 ...
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:123289 發表于 2019-3-23 22:13 | 只看該作者
想像一下:一個數據流從你面前流過,你如何知道誰是最后一個呢?
無法確定最后一個是誰,又何來倒數呢?
問題的前鍵就是這個!
也即通訊協議是如何定義:結束標記的!
你先規劃一個緩沖區,大小=4個字節+結束標記。每次收到數據就依序放入這個區域(循環放置,并設置一個指針PX,每次輸入使PX指向它,目的:可以知道何處是頭,何處是尾。)每次輸入后,在PX(注意是循環+,要保證不溢出)的地方,判一下是不是結束標記,如何是,則其它地方必是你要的4個字節。
回復

使用道具 舉報

板凳
ID:328334 發表于 2019-3-25 21:48 | 只看該作者
yzwzfyz 發表于 2019-3-24 07:14
想像一下:一個數據流從你面前流過,你如何知道誰是最后一個呢?
無法確定最后一個是誰,又何來倒數呢?
...

可以給個樣本程序嗎
回復

使用道具 舉報

地板
ID:481641 發表于 2019-4-5 16:34 | 只看該作者
按照通信協議來
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久久一二三区 | 无码一区二区三区视频 | 91成人免费观看 | 精品一二区| 国产成人精品一区二区三区在线 | 免费在线观看av的网站 | 亚洲不卡在线观看 | 99久久久久久久 | 久久国产视频网站 | 亚洲一区二区在线视频 | 亚洲精品一区二区 | 国产亚洲精品91 | 欧美1—12sexvideos | 麻豆91精品91久久久 | 国产高清久久 | 国产精品免费视频一区 | 九久久 | 在线视频成人 | 日韩字幕一区 | a网站在线观看 | 成人精品一区亚洲午夜久久久 | 精品三级在线观看 | 综合另类 | 欧美精品久久久久 | 中文字幕不卡一区 | 国产日韩精品一区二区三区 | 国产精品资源在线 | 中文字幕免费 | 一区二区三区av夏目彩春 | 午夜影院| 亚洲成人精品久久 | 国产一区2区 | 一区二区在线免费观看 | 久草色视频| 中文成人在线 | 妞干网福利视频 | 在线视频一区二区三区 | 97人人澡人人爽91综合色 | 久久亚洲一区 | 久久机热| 日本精品一区二区三区视频 |