您的位置 首页 系统

第61节:组合和非组合BCD码以及数值彼此转化

第六十一节:组合BCD码,非组合BCD码,以及数值三者之间的相互转换和关系。开场白:本来这一节打算讲大数据的加法运算的,但是考虑大数据运

第六十一节:组合BCD码非组合BCD码,以及数值三者之间的彼此转化和联系。
开场白:
原本这一节计划讲大数据的加法运算的,可是考虑大数据运算的根底对错组合BCD码,所以多添加一节讲BCD码的内容。
计算机中的BCD码,常常运用的有两种格局,即组合BCD码,非组合BCD码。
组合BCD码,是将两位十进制数,寄存在一个字节中,例如:十进制数51的寄存格局是0101 0001。
非组合BCD码,是将一个字节的低四位编码表明十进制数的一位,而高4位都为0。例如:十进制数51的占用了两个字节的空间,寄存格局为:00000101 00000001。
这一节要教我们两个知识点:
榜首个:怎么编写组合BCD码,非组合BCD码,以及数值三者之间的彼此转化函数。
第二个:经过转化函数的编写,重温前面几节所讲到的指针用法。

详细内容,请看源代码解说。

(1)硬件渠道:
依据朱兆祺51单片机学习板

(2)完结功用:
波特率是:9600 。
经过电脑串口调试帮手模仿上位机,往单片机发送EB 00 55 XX YY YY … YY YY指令,其间EB 00 55是数据头,XX 是指令类型。YY是详细的数据。
指令类型01代表发送的是数值,需求转成组合BCD码和非组合BCD码,而且回来上位机显现。
指令类型02代表发送的是组合BCD码,需求转成数值和非组合BCD码,而且回来上位机显现。
指令类型03代表发送的对错组合BCD码,需求转成数值和组合BCD码,而且回来上位机显现。

回来上位机的数据中,中心3个数据EE EE EE是分割线,为了便利调查,没实践意义。

例如:十进制的数据52013140,它的十六进制数据是03 19 A8 54。
(a)上位机发送数据:eb 00 55 01 03 19 a8 54
单片机回来:52 01 31 40 EE EE EE 05 02 00 01 03 01 04 00
(b)上位机发送组合BCD码:eb 00 55 02 52 01 31 40
单片机回来:03 19 A8 54 EE EE EE 05 02 00 01 03 01 04 00
(c)发送非组合BCD码:eb 00 55 03 05 02 00 01 03 01 04 00
单片机回来:03 19 A8 54 EE EE EE 52 01 31 40

(3)源代码解说如下:

  1. #include “REG52.H”
  2. #define const_voice_short40 //蜂鸣器短叫的持续时刻
  3. /* 注释一:
  4. * 留意,此处的const_rc_size是20,比之前章节的缓冲区略微改大了一点。
  5. */
  6. #define const_rc_size20//接纳串口中止数据的缓冲区数组巨细
  7. #define const_receive_time5//假如超越这个时刻没有串口数据过来,就以为一串数据现已悉数接纳完,这个时刻依据实践情况来调整巨细
  8. void initial_myself(void);
  9. void initial_peripheral(void);
  10. void delay_long(unsigned int uiDelaylong);
  11. void delay_short(unsigned int uiDelayShort);
  12. void T0_time(void);//守时中止函数
  13. void usart_receive(void); //串口接纳中止函数
  14. void usart_service(void);//串口服务程序,在main函数里
  15. void eusart_send(unsigned char ucSendData);
  16. void number_to_BCD4(const unsigned char *p_ucNumber,unsigned char *p_ucBCD_bit4);//把数值转化成组合BCD码
  17. void number_to_BCD8(const unsigned char *p_ucNumber,unsigned char *p_ucBCD_bit8);//把数值转化成非组合BCD码
  18. void BCD4_to_number(const unsigned char *p_ucBCD_bit4,unsigned char *p_ucNumber); //组合BCD码转成数值
  19. void BCD4_to_BCD8(const unsigned char *p_ucBCD_bit4,unsigned char *p_ucBCD_bit8); //组合BCD码转成非组合BCD码
  20. void BCD8_to_number(const unsigned char *p_ucBCD_bit8,unsigned char *p_ucNumber); //非组合BCD码转成数值
  21. void BCD8_to_BCD4(const unsigned char *p_ucBCD_bit8,unsigned char *p_ucBCD_bit4); //非组合BCD码转成组合BCD码
  22. sbit beep_dr=P2^7; //蜂鸣器的驱动IO口
  23. unsigned intuiSendCnt=0; //用来辨认串口是否接纳完一串数据的计时器
  24. unsigned char ucSendLock=1; //串口服务程序的自锁变量,每次接纳完一串数据只处理一次
  25. unsigned intuiRcregTotal=0;//代表当时缓冲区现已接纳了多少个数据
  26. unsigned char ucRcregBuf[const_rc_size]; //接纳串口中止数据的缓冲区数组
  27. unsigned intuiRcMoveIndex=0;//用来解析数据协议的中心变量
  28. /* 注释二:
  29. * 留意,本程序规则数值的最大规模是0至99999999
  30. * 数组中的数据。高位在数组下标大的方向,低位在数组下标小的方向。
  31. */
  32. unsigned char ucBufferNumber[4]; //数值,用4个字节表明long类型的数值
  33. unsigned char ucBufferBCB_bit4[4]; //组合BCD码
  34. unsigned char ucBufferBCB_bit8[8]; //非组合BCD码
  35. void main()
  36. {
  37. initial_myself();
  38. delay_long(100);
  39. initial_peripheral();
  40. while(1)
  41. {
  42. usart_service();//串口服务程序
  43. }
  44. }
  45. void number_to_BCD4(const unsigned char *p_ucNumber,unsigned char *p_ucBCD_bit4)//把数值转化成组合BCD码
  46. {
  47. unsigned long ulNumberTemp=0;
  48. unsigned char ucTemp=0;
  49. ulNumberTemp=p_ucNumber[3];//把4个字节的数值合并成一个long类型数据
  50. ulNumberTemp=ulNumberTemp<<8;
  51. ulNumberTemp=ulNumberTemp+p_ucNumber[2];
  52. ulNumberTemp=ulNumberTemp<<8;
  53. ulNumberTemp=ulNumberTemp+p_ucNumber[1];
  54. ulNumberTemp=ulNumberTemp<<8;
  55. ulNumberTemp=ulNumberTemp+p_ucNumber[0];
  56. p_ucBCD_bit4[3]=ulNumberTemp%100000000/10000000;
  57. p_ucBCD_bit4[3]=p_ucBCD_bit4[3]<<4; //前半4位存第8位组合BCD码
  58. ucTemp=ulNumberTemp%10000000/1000000;
  59. p_ucBCD_bit4[3]=p_ucBCD_bit4[3]+ucTemp; //后半4位存第7位组合BCD码
  60. p_ucBCD_bit4[2]=ulNumberTemp%1000000/100000;
  61. p_ucBCD_bit4[2]=p_ucBCD_bit4[2]<<4; //前半4位存第6位组合BCD码
  62. ucTemp=ulNumberTemp%100000/10000;
  63. p_ucBCD_bit4[2]=p_ucBCD_bit4[2]+ucTemp;//后半4位存第5位组合BCD码
  64. p_ucBCD_bit4[1]=ulNumberTemp%10000/1000;
  65. p_ucBCD_bit4[1]=p_ucBCD_bit4[1]<<4; //前半4位存第4位组合BCD码
  66. ucTemp=ulNumberTemp%1000/100;
  67. p_ucBCD_bit4[1]=p_ucBCD_bit4[1]+ucTemp;//后半4位存第3位组合BCD码
  68. p_ucBCD_bit4[0]=ulNumberTemp%100/10;
  69. p_ucBCD_bit4[0]=p_ucBCD_bit4[0]<<4; //前半4位存第2位组合BCD码
  70. ucTemp=ulNumberTemp%10;
  71. p_ucBCD_bit4[0]=p_ucBCD_bit4[0]+ucTemp;//后半4位存第1位组合BCD码
  72. }
  73. void number_to_BCD8(const unsigned char *p_ucNumber,unsigned char *p_ucBCD_bit8)//把数值转化成非组合BCD码
  74. {
  75. unsigned long ulNumberTemp=0;
  76. ulNumberTemp=p_ucNumber[3];//把4个字节的数值合并成一个long类型数据
  77. ulNumberTemp=ulNumberTemp<<8;
  78. ulNumberTemp=ulNumberTemp+p_ucNumber[2];
  79. ulNumberTemp=ulNumberTemp<<8;
  80. ulNumberTemp=ulNumberTemp+p_ucNumber[1];
  81. ulNumberTemp=ulNumberTemp<<8;
  82. ulNumberTemp=ulNumberTemp+p_ucNumber[0];
  83. p_ucBCD_bit8[7]=ulNumberTemp%100000000/10000000;//一个字节8位存储第8位非组合BCD码
  84. p_ucBCD_bit8[6]=ulNumberTemp%10000000/1000000;//一个字节8位存储第7位非组合BCD码
  85. p_ucBCD_bit8[5]=ulNumberTemp%1000000/100000;//一个字节8位存储第6位非组合BCD码
  86. p_ucBCD_bit8[4]=ulNumberTemp%100000/10000;//一个字节8位存储第5位非组合BCD码
  87. p_ucBCD_bit8[3]=ulNumberTemp%10000/1000;//一个字节8位存储第4位非组合BCD码
  88. p_ucBCD_bit8[2]=ulNumberTemp%1000/100;//一个字节8位存储第3位非组合BCD码
  89. p_ucBCD_bit8[1]=ulNumberTemp%100/10;//一个字节8位存储第2位非组合BCD码
  90. p_ucBCD_bit8[0]=ulNumberTemp%10;//一个字节8位存储第1位非组合BCD码
  91. }
  92. void BCD4_to_number(const unsigned char *p_ucBCD_bit4,unsigned char *p_ucNumber) //组合BCD码转成数值
  93. {
  94. unsigned long ulTmep;
  95. unsigned long ulSum;
  96. ulSum=0;//累加和数值清零
  97. ulTmep=0;
  98. ulTmep=p_ucBCD_bit4[3];
  99. ulTmep=ulTmep>>4;//把组合BCD码第8位分化出来
  100. ulTmep=ulTmep*10000000;
  101. ulSum=ulSum+ulTmep; //累加各位数值
  102. ulTmep=0;
  103. ulTmep=p_ucBCD_bit4[3];
  104. ulTmep=ulTmep&0x0000000f;//把组合BCD码第7位分化出来
  105. ulTmep=ulTmep*1000000;
  106. ulSum=ulSum+ulTmep; //累加各位数值
  107. ulTmep=0;
  108. ulTmep=p_ucBCD_bit4[2];
  109. ulTmep=ulTmep>>4;//把组合BCD码第6位分化出来
  110. ulTmep=ulTmep*100000;
  111. ulSum=ulSum+ulTmep; //累加各位数值
  112. ulTmep=0;
  113. ulTmep=p_ucBCD_bit4[2];
  114. ulTmep=ulTmep&0x0000000f;//把组合BCD码第5位分化出来
  115. ulTmep=ulTmep*10000;
  116. ulSum=ulSum+ulTmep; //累加各位数值
  117. ulTmep=0;
  118. ulTmep=p_ucBCD_bit4[1];
  119. ulTmep=ulTmep>>4;//把组合BCD码第4位分化出来
  120. ulTmep=ulTmep*1000;
  121. ulSum=ulSum+ulTmep; //累加各位数值
  122. ulTmep=0;
  123. ulTmep=p_ucBCD_bit4[1];
  124. ulTmep=ulTmep&0x0000000f;//把组合BCD码第3位分化出来
  125. ulTmep=ulTmep*100;
  126. ulSum=ulSum+ulTmep; //累加各位数值
  127. ulTmep=0;
  128. ulTmep=p_ucBCD_bit4[0];
  129. ulTmep=ulTmep>>4;//把组合BCD码第2位分化出来
  130. ulTmep=ulTmep*10;
  131. ulSum=ulSum+ulTmep; //累加各位数值
  132. ulTmep=0;
  133. ulTmep=p_ucBCD_bit4[0];
  134. ulTmep=ulTmep&0x0000000f;//把组合BCD码第1位分化出来
  135. ulTmep=ulTmep*1;
  136. ulSum=ulSum+ulTmep; //累加各位数值
  137. //以上代码十分有规则,有爱好的读者也能够自己想办法把它压缩成一个for循环的函数,能够极大节约容量。
  138. p_ucNumber[3]=ulSum>>24;//把long类型数据分化成4个字节
  139. p_ucNumber[2]=ulSum>>16;
  140. p_ucNumber[1]=ulSum>>8;
  141. p_ucNumber[0]=ulSum;
  142. }
  143. void BCD4_to_BCD8(const unsigned char *p_ucBCD_bit4,unsigned char *p_ucBCD_bit8) //组合BCD码转成非组合BCD码
  144. {
  145. unsigned char ucTmep;
  146. ucTmep=p_ucBCD_bit4[3];
  147. p_ucBCD_bit8[7]=ucTmep>>4; //把组合BCD码第8位分化出来
  148. p_ucBCD_bit8[6]=ucTmep&0x0f;//把组合BCD码第7位分化出来
  149. ucTmep=p_ucBCD_bit4[2];
  150. p_ucBCD_bit8[5]=ucTmep>>4; //把组合BCD码第6位分化出来
  151. p_ucBCD_bit8[4]=ucTmep&0x0f;//把组合BCD码第5位分化出来
  152. ucTmep=p_ucBCD_bit4[1];
  153. p_ucBCD_bit8[3]=ucTmep>>4; //把组合BCD码第4位分化出来
  154. p_ucBCD_bit8[2]=ucTmep&0x0f;//把组合BCD码第3位分化出来
  155. ucTmep=p_ucBCD_bit4[0];
  156. p_ucBCD_bit8[1]=ucTmep>>4; //把组合BCD码第2位分化出来
  157. p_ucBCD_bit8[0]=ucTmep&0x0f;//把组合BCD码第1位分化出来
  158. }
  159. void BCD8_to_number(const unsigned char *p_ucBCD_bit8,unsigned char *p_ucNumber) //非组合BCD码转成数值
  160. {
  161. unsigned long ulTmep;
  162. unsigned long ulSum;
  163. ulSum=0;//累加和数值清零
  164. ulTmep=0;
  165. ulTmep=p_ucBCD_bit8[7];
  166. ulTmep=ulTmep*10000000;
  167. ulSum=ulSum+ulTmep; //累加各位数值
  168. ulTmep=0;
  169. ulTmep=p_ucBCD_bit8[6];
  170. ulTmep=ulTmep*1000000;
  171. ulSum=ulSum+ulTmep; //累加各位数值
  172. ulTmep=0;
  173. ulTmep=p_ucBCD_bit8[5];
  174. ulTmep=ulTmep*100000;
  175. ulSum=ulSum+ulTmep; //累加各位数值
  176. ulTmep=0;
  177. ulTmep=p_ucBCD_bit8[4];
  178. ulTmep=ulTmep*10000;
  179. ulSum=ulSum+ulTmep; //累加各位数值
  180. ulTmep=0;
  181. ulTmep=p_ucBCD_bit8[3];
  182. ulTmep=ulTmep*1000;
  183. ulSum=ulSum+ulTmep; //累加各位数值
  184. ulTmep=0;
  185. ulTmep=p_ucBCD_bit8[2];
  186. ulTmep=ulTmep*100;
  187. ulSum=ulSum+ulTmep; //累加各位数值
  188. ulTmep=0;
  189. ulTmep=p_ucBCD_bit8[1];
  190. ulTmep=ulTmep*10;
  191. ulSum=ulSum+ulTmep; //累加各位数值
  192. ulTmep=0;
  193. ulTmep=p_ucBCD_bit8[0];
  194. ulTmep=ulTmep*1;
  195. ulSum=ulSum+ulTmep; //累加各位数值
  196. //以上代码十分有规则,有爱好的读者也能够自己想办法把它压缩成一个for循环的函数,能够极大节约容量。
  197. p_ucNumber[3]=ulSum>>24;//把long类型数据分化成4个字节
  198. p_ucNumber[2]=ulSum>>16;
  199. p_ucNumber[1]=ulSum>>8;
  200. p_ucNumber[0]=ulSum;
  201. }
  202. void BCD8_to_BCD4(const unsigned char *p_ucBCD_bit8,unsigned char *p_ucBCD_bit4) //非组合BCD码转成组合BCD码
  203. {
  204. unsigned char ucTmep;
  205. ucTmep=p_ucBCD_bit8[7]; //把非组合BCD码第8位分化出来
  206. p_ucBCD_bit4[3]=ucTmep<<4;
  207. p_ucBCD_bit4[3]=p_ucBCD_bit4[3]+p_ucBCD_bit8[6]; //把非组合BCD码第7位分化出来
  208. ucTmep=p_ucBCD_bit8[5]; //把非组合BCD码第6位分化出来
  209. p_ucBCD_bit4[2]=ucTmep<<4;
  210. p_ucBCD_bit4[2]=p_ucBCD_bit4[2]+p_ucBCD_bit8[4]; //把非组合BCD码第5位分化出来
  211. ucTmep=p_ucBCD_bit8[3]; //把非组合BCD码第4位分化出来
  212. p_ucBCD_bit4[1]=ucTmep<<4;
  213. p_ucBCD_bit4[1]=p_ucBCD_bit4[1]+p_ucBCD_bit8[2]; //把非组合BCD码第3位分化出来
  214. ucTmep=p_ucBCD_bit8[1]; //把非组合BCD码第2位分化出来
  215. p_ucBCD_bit4[0]=ucTmep<<4;
  216. p_ucBCD_bit4[0]=p_ucBCD_bit4[0]+p_ucBCD_bit8[0]; //把非组合BCD码第1位分化出来
  217. }
  218. void usart_service(void)//串口服务程序,在main函数里
  219. {
  220. unsigned char i=0;
  221. if(uiSendCnt>=const_receive_time&&ucSendLock==1) //阐明超越了必定的时刻内,再也没有新数据从串口来
  222. {
  223. ucSendLock=0; //处理一次就锁起来,不必每次都进来,除非有新接纳的数据
  224. //下面的代码进入数据协议解析和数据处理的阶段
  225. uiRcMoveIndex=0; //由所以判别数据头,所以下标移动变量从数组的0开端向最尾端移动
  226. while(uiRcregTotal>=5&&uiRcMoveIndex<=(uiRcregTotal-5))
  227. {
  228. if(ucRcregBuf[uiRcMoveIndex+0]==0xeb&&ucRcregBuf[uiRcMoveIndex+1]==0x00&&ucRcregBuf[uiRcMoveIndex+2]==0x55)//数据头eb 00 55的判别
  229. {
  230. switch(ucRcregBuf[uiRcMoveIndex+3])//依据指令类型来进行不同的处理
  231. {
  232. case 1://接纳到的是数值,需求转成组合BCD码和非组合BCD码
  233. for(i=0;i<4;i++)
  234. {
  235. ucBufferNumber[3-i]=ucRcregBuf[uiRcMoveIndex+4+i]; //从串口接纳到的数据,留意,高位在数组下标大的方向
  236. }
  237. number_to_BCD4(ucBufferNumber,ucBufferBCB_bit4);//把数值转化成组合BCD码
  238. number_to_BCD8(ucBufferNumber,ucBufferBCB_bit8);//把数值转化成非组合BCD码
  239. for(i=0;i<4;i++)
  240. {
  241. eusart_send(ucBufferBCB_bit4[3-i]);////把组合BCD码回来给上位机调查,留意,高位在数组下标大的方向
  242. }
  243. eusart_send(0xee);//为了便利上位机调查,多发送3个字节ee ee ee作为分割线
  244. eusart_send(0xee);
  245. eusart_send(0xee);
  246. for(i=0;i<8;i++)
  247. {
  248. eusart_send(ucBufferBCB_bit8[7-i]);////把非组合BCD码回来给上位机调查,留意,高位在数组下标大的方向
  249. }
  250. break;
  251. case 2://接纳到的是组合BCD码,需求转成数值和非组合BCD码
  252. for(i=0;i<4;i++)
  253. {
  254. ucBufferBCB_bit4[3-i]=ucRcregBuf[uiRcMoveIndex+4+i]; //从串口接纳到的组合BCD码,留意,高位在数组下标大的方向
  255. }
  256. BCD4_to_number(ucBufferBCB_bit4,ucBufferNumber); //组合BCD码转成数值
  257. BCD4_to_BCD8(ucBufferBCB_bit4,ucBufferBCB_bit8); //组合BCD码转成非组合BCD码
  258. for(i=0;i<4;i++)
  259. {
  260. eusart_send(ucBufferNumber[3-i]);////把数值回来给上位机调查,留意,高位在数组下标大的方向
  261. }
  262. eusart_send(0xee);//为了便利上位机调查,多发送3个字节ee ee ee作为分割线
  263. eusart_send(0xee);
  264. eusart_send(0xee);
  265. for(i=0;i<8;i++)
  266. {
  267. eusart_send(ucBufferBCB_bit8[7-i]);////把非组合BCD码回来给上位机调查,留意,高位在数组下标大的方向
  268. }
  269. break;
  270. case 3://接纳到的对错组合BCD码,需求转成数值和组合BCD码
  271. for(i=0;i<8;i++)
  272. {
  273. ucBufferBCB_bit8[7-i]=ucRcregBuf[uiRcMoveIndex+4+i]; //从串口接纳到的非组合BCD码,留意,高位在数组下标大的方向
  274. }
  275. BCD8_to_number(ucBufferBCB_bit8,ucBufferNumber); //非组合BCD码转成数值
  276. BCD8_to_BCD4(ucBufferBCB_bit8,ucBufferBCB_bit4); //非组合BCD码转成组合BCD码
  277. for(i=0;i<4;i++)
  278. {
  279. eusart_send(ucBufferNumber[3-i]);////把数值回来给上位机调查
  280. }
  281. eusart_send(0xee);//为了便利上位机调查,多发送3个字节ee ee ee作为分割线,留意,高位在数组下标大的方向
  282. eusart_send(0xee);
  283. eusart_send(0xee);
  284. for(i=0;i<4;i++)
  285. {
  286. eusart_send(ucBufferBCB_bit4[3-i]);////把组合BCD码回来给上位机调查,留意,高位在数组下标大的方向
  287. }
  288. break;
  289. }
  290. break; //退出循环
  291. }
  292. uiRcMoveIndex++; //由于是判别数据头,游标向着数组最尾端的方向移动
  293. }
  294. uiRcregTotal=0;//清空缓冲的下标,便利下次从头从0下标开端承受新数据
  295. }
  296. }
  297. void eusart_send(unsigned char ucSendData) //往上位机发送一个字节的函数
  298. {
  299. ES = 0; //关串口中止
  300. TI = 0; //清零串口发送完结中止请求标志
  301. SBUF =ucSendData; //发送一个字节
  302. delay_short(400);//每个字节之间的延时,这儿十分要害,也是最简略犯错的当地。延时的巨细请依据实践项目来调整
  303. TI = 0; //清零串口发送完结中止请求标志
  304. ES = 1; //答应串口中止
  305. }
  306. void T0_time(void) interrupt 1 //守时中止
  307. {
  308. TF0=0;//铲除中止标志
  309. TR0=0; //关中止
  310. if(uiSendCnt
  311. {
  312. uiSendCnt++; //表面上这个数据不断累加,可是在串口中止里,每接纳一个字节它都会被清零,除非这个中心没有串口数据过来
  313. ucSendLock=1; //开自锁标志
  314. }
  315. TH0=0xfe; //重装初始值(65535-500)=65035=0xfe0b
  316. TL0=0x0b;
  317. TR0=1;//开中止
  318. }
  319. void usart_receive(void) interrupt 4 //串口接纳数据中止
  320. {
  321. if(RI==1)
  322. {
  323. RI = 0;
  324. ++uiRcregTotal;
  325. if(uiRcregTotal>const_rc_size)//超越缓冲区
  326. {
  327. uiRcregTotal=const_rc_size;
  328. }
  329. ucRcregBuf[uiRcregTotal-1]=SBUF; //将串口接纳到的数据缓存到接纳缓冲区里
  330. uiSendCnt=0;//及时喂狗,尽管main函数那儿不断在累加,可是只需串口的数据还没发送结束,那么它永久也长不大,由于每个中止都被清零。
  331. }
  332. else//发送中止,及时把发送中止标志位清零
  333. {
  334. TI = 0;
  335. }
  336. }
  337. void delay_long(unsigned int uiDelayLong)
  338. {
  339. unsigned int i;
  340. unsigned int j;
  341. for(i=0;i
  342. {
  343. for(j=0;j<500;j++)//内嵌循环的空指令数量
  344. {
  345. ; //一个分号相当于履行一条空语句
  346. }
  347. }
  348. }
  349. void delay_short(unsigned int uiDelayShort)
  350. {
  351. unsigned int i;
  352. for(i=0;i
  353. {
  354. ; //一个分号相当于履行一条空语句
  355. }
  356. }
  357. void initial_myself(void)//榜首区 初始化单片机
  358. {
  359. beep_dr=1; //用PNP三极管操控蜂鸣器,输出高电平时不叫。
  360. //装备守时器
  361. TMOD=0x01;//设置守时器0为工作方式1
  362. TH0=0xfe; //重装初始值(65535-500)=65035=0xfe0b
  363. TL0=0x0b;
  364. //装备串口
  365. SCON=0x50;
  366. TMOD=0X21;
  367. TH1=TL1=-(11059200L/12/32/9600);//这段装备代码详细是什么意思,我也不太清楚,反正是跟串口波特率有关。
  368. TR1=1;
  369. }
  370. void initial_peripheral(void) //第二区 初始化外围
  371. {
  372. EA=1; //开总中止
  373. ES=1; //答应串口中止
  374. ET0=1; //答应守时中止
  375. TR0=1; //发动守时中止
  376. }

总结陈词:
有了这一节非组合BCD的根底知识,下一节就开端讲大数据的算法程序。这些算法程序常常要用在计算器,工控,以及高精度的仪器仪表等范畴。C言语的语法中不是现已供给了+,-,*,/这些运算符号吗?为什么还要专门写算法程序?由于那些运算符只能进行简略的运算,一旦数据超越了unsigned long(4个字节)的规模就会犯错。而这种大数据算法的程序是什么样的?欲知概况,请听下回分化—-大数据的加法运算。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qianrushi/xitong/262061.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部