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

第62节:大数据的加法运算

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

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

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

网站地图

Top