【转载】单片机模块化程序5-丢给你个环形队列玩玩

[复制链接]
1042|13
 楼主| HuangHongLun 发表于 2019-10-31 16:23 | 显示全部楼层 |阅读模式
一,其实环形队列就是利用一些函数把一个数组的首位连接起来,然后实现如下功能
环形队列的存在解决了一个最典型的问题:
假设我需要处理10000个字节的数据,就是串口一次性会发过来10000个字节,然后单片机每次取10个字节处理,然后处理1000次就处理完了
现在的问题是我的单片机的RAM没有10000字节的内存了,该咋办???
819239-20191014042157921-556686012.jpg

利用环形队列的话,我可以定义一个20字节的数组,串口中断里面不停的往里面存数据,我主循环不停的查询这个数组里面是否够10字节了,
如果够了,我就从里面取出来10字节处理,然后不停的循环. 这样的话就可以用20字节的数组处理掉10000字节数据.

 楼主| HuangHongLun 发表于 2019-10-31 16:27 | 显示全部楼层
二,拷贝文件到工程
819239-20191014042051966-1425870901.jpg


819239-20191014043538487-393479271.jpg
819239-20191014043557161-1443671868.jpg


819239-20191014043633160-115625462.jpg

 楼主| HuangHongLun 发表于 2019-10-31 16:27 | 显示全部楼层
三,创建一个数组   创建一个环形队列管理变量  然后把数组交给环形队列函数去管理
819239-20191014044715333-1496359182.jpg


819239-20191014044744763-143698887.jpg


819239-20191014044831797-219296235.jpg





 楼主| HuangHongLun 发表于 2019-10-31 16:27 | 显示全部楼层
四,把数据写入环形队列

819239-20191014120819830-1714060810.jpg

 楼主| HuangHongLun 发表于 2019-10-31 16:28 | 显示全部楼层
五,读出数据,输出每10个数据的累加和

819239-20191014122622724-643259016.jpg






819239-20191014122724463-394405330.jpg

 楼主| HuangHongLun 发表于 2019-10-31 16:29 | 显示全部楼层
六,测试
01 01 01 01 01 01 01 01 01 01 01   先发 11个0x01
819239-20191014122919484-178964738.jpg


再来个76个数据
01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01
819239-20191014123029471-1621857955.jpg


更来个1200个数据
01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01
819239-20191014123452675-1568690139.jpg


这就体现了  四两拨千斤

lvben5d 发表于 2019-10-31 16:33 | 显示全部楼层
环形数组 对于几十K的RAM还是浪费, 应该用环形字节缓冲区才对哦。 真要是那么紧凑的情况下。
 楼主| HuangHongLun 发表于 2019-10-31 17:47 | 显示全部楼层
七,注意事项
如果主循环处理的不及时
819239-20191014123612933-572666108.jpg


如果环形队列满了,这个标志位将置位
处理数据的时候判断一下这个标志位是否置位,如果置位说明本次的数据有丢失!

drer 发表于 2019-11-13 10:33 | 显示全部楼层
非常感谢分享
gwsan 发表于 2019-11-13 10:56 | 显示全部楼层
非常不错的资料
kxsi 发表于 2019-11-13 11:32 | 显示全部楼层
非常不错的资料
nawu 发表于 2019-11-13 11:46 | 显示全部楼层
非常不错的资料
qcliu 发表于 2019-11-13 12:00 | 显示全部楼层
非常不错的资料
tfqi 发表于 2019-11-13 12:43 | 显示全部楼层
非常不错的资料
您需要登录后才可以回帖 登录 | 注册

本版积分规则

50

主题

440

帖子

2

粉丝
快速回复 在线客服 返回列表 返回顶部