18363890557 发表于 2020-9-21 09:35:42

04-单片机接收数据之环形队列




1. 前言在单片机通信项目中,经常会遇到接收大量数据并处理,但是单片机RAM不够用的问题.
列如:单片机循环接收不定长的数据(数据量很大,RAM不够用),我需要在数据接收的时候,计算所有数据的累加和.
注:有可能别人会想,我直接在中断里面累加就可以实现.


我只是说一个简单的需求,方便大家理解环形队列,
用户主要需要明白用环形队列可以解决什么问题!

2. 方案思考单片机没有这么大内存供开发者使用,需要一边接收一边处理!
要是下面这样一个数组就好了
我不停的从数组首地址开始往里面存数据,然后又不停的从数组首地址开始取出里面的数据,
当存到了数组的尾地址,再存数据的时候,可以从头开始存
当取到了数组的尾地址以后,再取的时候,可以从头开始取


上面的整个圈是一个数组,红色箭头代表存数据,蓝色箭头代表取数据.
凡是蓝色箭头已经取出的地方,红色箭头可以再次往里面存.

有了上面的这样一个数组以后,接收的数据不停的存入数组,在处理数据的地方不停的取出,形成了一个循环!
这种模式有个名词:环形队列

提示:
实际上就是定义一个数组,然后用一些程序把数组的操作变为上面的形式!
3. 程序结构LoopList: 把数组操作成环形队列的程序


4. 程序说明1.定义数组,数组交给LoopList管理
定义的缓存数组只有20字节.

2.串口接收的数据交于LoopList存入数组


3.主循环不停的判断环形队列里面的数据个数
如果里面有数据,则取出来做累加

5. 测试1.发给串口2个数据

2.发给串口50个数据

4.发给串口500个数据

5.发给串口3000个数据

6. 提醒用户是否感受到了环形队列所能解决的问题??


串口在接收数据不停的插入缓存队列里面的时候,主循环不停的从里面取出数据处理.
这样就形成了一个环形结构,不停的存不停的取!


程序里面只用了20字节数组就接收处理了3000字节的数据.
正所谓:四两拨千斤


在使用的时候需要注意:
如果取数据的速度太慢,就会造成环形队列满.
用户根据实际情况调整缓存数组大小即可.



7. 结语整个程序实际上就是把数据存入数组,然后从数组取出来数据处理!
只不过把数组交给了环形队列程序进行管理
存和取都是通过环形队列提供的函数进行操作
环形队列管理程序就是把数组形成了一个环.


环形队列用的最典型的地方:远程更新单片机程序
1.单片机程序一般都很大,单片机的RAM根本放不下
2.需要一边接收一边写入Flash里面,操作Flash会有延时


在不让程序文件分段下载的情况下,为了解决上面的问题,
环形队列是最好的选择.
我的所有的远程更新都是使用的环形队列实现.
页: [1]
查看完整版本: 04-单片机接收数据之环形队列