串口接收的环形队列

2020-01-14 18:58发布

串口接收的环形队列,看到坛子里面有人说串口接收环形队列,可以解决内部ram不足,以很小的环形队列接收较多的数据
我可以不可以这样理解
定义一个数组,data[20];譬如接收满20个,就把这个20个处理了,然后清空在接收下面的,就是接收到data[19]就转向data[0]

是这个意思么,有没有实际运用啊,或者说有个 例子看看
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
34条回答
yibunihao
2020-01-16 04:53
回复【12楼】myqiang1990 小松鼠
回复【11楼】mcu_lover  
-----------------------------------------------------------------------
所以我觉得奇怪、、、这种环形列队接受方式,在什么样的情况下可以用?按照我的理解就是:比如我接受10k数据,但是我的列队缓冲只开辟了2k,那么应该就是这样:每次接收2k数据后,马上就要去处理一次数据,然后清空缓冲区,然后再去接收,直到5次接收完!但是对于我这样一次性要处理10k的数据,好像不适用啊。。是不是这样??
-----------------------------------------------------------------------

如果这样的话就不符合环形缓冲的初衷了哈,环形缓冲是为了做到一边收数据一边处理在数据量密集的时候不至于丢掉数据或者数据产生冲突。如果你要接收的10K数据是一个最小单位,就是说处理的时候也要是10K一起处理,那么你的缓冲区至少也要开到10K,而且如果只开10K的话是体现不到环形缓冲的作用的;如果只是一次接收10K,但是处理却可以1K处理一次(举例),那么就可以在接收了1K的时候去处理数据,此时中断还在接收,数据仍然在一个一个往缓冲区里放,当接收到2K的时候,前面1K已经处理完成,这样缓冲区里就又有了可利用的1K空间,如此循环。开缓冲区最大的作用是为了防止丢码,在处理速度够快的时候可以节省RAM空间。

一周热门 更多>