找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4571|回复: 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(注意是循环+,要保证不溢出)的地方,判一下是不是结束标记,如何是 ...
回复

使用道具 举报

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 单片机教程网

快速回复 返回顶部 返回列表