微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 第63节:大数据的减法运算

第63节:大数据的减法运算

时间:11-22 来源:互联网 点击:

  1. case 1,获取第2个参与运行的数,在这里是加数
  2. {
  3. if(ucRcregBuf[uiRcMoveIndex+3+i]==0x0d&&ucRcregBuf[uiRcMoveIndex+4+i]==0x0a) //结束标志
  4. {
  5. for(k=0;k
  6. {
  7. ucDataBCD4_2[k]=ucRcregBuf[uiRcMoveIndex+3+i-1-k]; //注意,接收到的数组数据与实际存储的数组数据的下标方向是相反的
  8. }
  9. break; //截取数据完成。直接跳出截取数据的while(i<(BCD8_MAX+4))循环
  10. }
  11. else
  12. {
  13. i++;
  14. ucDataBCD4_cnt_2++;//统计第2个有效数据的长度
  15. }
  16. }
  17. }
  18. //注意ucDataBCD8_cnt_1和ucDataBCD8_cnt_2要带地址符号&传址进去
  19. BCD4_to_BCD8(ucDataBCD4_1,ucDataBCD4_cnt_1,ucDataBCD8_1,&ucDataBCD8_cnt_1); //把接收到的组合BCD码转换成非组合BCD码第1个数
  20. BCD4_to_BCD8(ucDataBCD4_2,ucDataBCD4_cnt_2,ucDataBCD8_2,&ucDataBCD8_cnt_2); //把接收到的组合BCD码转换成非组合BCD码第2个数
  21. ClearAllData(BCD8_MAX,ucDataBCD8_3);//清零第3个参与运算的数据,用来接收运行的结果
  22. ucResultFlag=SubData(ucDataBCD8_1,ucDataBCD8_2,ucDataBCD8_3); //相减运算,结果放在ucDataBCD8_3数组里
  23. if(ucResultFlag==11) //表示运算结果没有超范围
  24. {
  25. ucDataBCD8_cnt_3=GetDataLength(ucDataBCD8_3,BCD8_MAX);//获取运算结果的有效字节数
  26. BCD8_to_BCD4(ucDataBCD8_3,ucDataBCD8_cnt_3,ucDataBCD4_3,&ucDataBCD4_cnt_3); //把非组合BCD码转成组合BCD码。注意,&ucDataBCD4_cnt_3带地址符号&
  27. for(k=0;k
  28. {
  29. eusart_send(ucDataBCD4_3[ucDataBCD4_cnt_3-1-k]); //往上位机发送一个字节的函数
  30. }
  31. }
  32. else //运算结果超范围,返回EE EE EE
  33. {
  34. eusart_send(0xee); //往上位机发送一个字节的函数
  35. eusart_send(0xee); //往上位机发送一个字节的函数
  36. eusart_send(0xee); //往上位机发送一个字节的函数
  37. }
  38. break; //退出循环
  39. }
  40. uiRcMoveIndex++; //因为是判断数据头,游标向着数组最尾端的方向移动
  41. }
  42. ucRcregBuf[0]=0; //把数据头清零,方便下次接收判断新数据
  43. ucRcregBuf[1]=0;
  44. ucRcregBuf[2]=0;
  45. uiRcregTotal=0;//清空缓冲的下标,方便下次重新从0下标开始接受新数据
  46. }
  47. }
  48. void eusart_send(unsigned char ucSendData) //往上位机发送一个字节的函数
  49. {
  50. ES = 0; //关串口中断
  51. TI = 0; //清零串口发送完成中断请求标志
  52. SBUF =ucSendData; //发送一个字节
  53. delay_short(400);//每个字节之间的延时,这里非常关键,也是最容易出错的地方。延时的大小请根据实际项目来调整
  54. TI = 0; //清零串口发送完成中断请求标志
  55. ES = 1; //允许串口中断
  56. }
  57. void T0_time(void) interrupt 1 //定时中断
  58. {
  59. TF0=0;//清除中断标志
  60. TR0=0; //关中断
  61. if(uiSendCnt
  62. {
  63. uiSendCnt++; //表面上这个数据不断累加,但是在串口中断里,每接收一个字节它都会被清零,除非这个中间没有串口数据过来
  64. ucSendLock=1; //开自锁标志
  65. }
  66. TH0=0xfe; //重装初始值(65535-500)=65035=0xfe0b
  67. TL0=0x0b;
  68. TR0=1;//开中断
  69. }
  70. void usart_receive(void) interrupt 4 //串口接收数据中断
  71. {
  72. if(RI==1)
  73. {
  74. RI = 0;
  75. ++uiRcregTotal;
  76. if(uiRcregTotal>const_rc_size)//超过缓冲区
  77. {
  78. uiRcregTotal=const_rc_size;
  79. }
  80. ucRcregBuf[uiRcregTotal-1]=SBUF; //将串口接收到的数据缓存到接收缓冲区里
  81. uiSendCnt=0;//及时喂狗,虽然main函数那边不断在累加,但是只要串口的数据还没发送完毕,那么它永远也长不大,因为每个中断都被清零。
  82. }
  83. else//发送中断,及时把发送中断标志位清零
  84. {
  85. TI = 0;
  86. }
  87. }
  88. void delay_long(unsigned int uiDelayLong)
  89. {
  90. unsigned int i;
  91. unsigned int j;
  92. for(i=0;i
  93. {
  94. for(j=0;j<500;j++)//内嵌循环的空指令数量
  95. {
  96. ; //一个分号相当于执行一条空语句
  97. }
  98. }
  99. }
  100. void delay_short(unsigned int uiDelayShort)
  101. {
  102. unsigned int i;
  103. for(i=0;i
  104. {
  105. ; //一个分号相当于执行一条空语句
  106. }
  107. }
  108. void initial_myself(void)//第一区 初始化单片机
  109. {
  110. beep_dr=1; //用PNP三极管控制蜂鸣器,输出高电平时不叫。
  111. //配置定时器
  112. TMOD=0x01;//设置定时器0为工作方式1
  113. TH0=0xfe; //重装初始值(65535-500)=65035=0xfe0b
  114. TL0=0x0b;
  115. //配置串口
  116. SCON=0x50;
  117. TMOD=0X21;
  118. TH1=TL1=-(1

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top