我是用原子的F7开发板,试了下使用链队列从串口接收数据,串口接收数据波特率为115200,一边收一边在main函数while(1)中检测队列是否为空,不空则将数据发送出来,但是当发送大量数据时时不时就会少几个字节,如果使用数组实现队列就不会出现这种问题,链队列中malloc使用C库函数和原子的内存管理都试过,都会出现漏字节的问题,想问下这种情况怎么回事呢?是malloc执行太耗时间了吗?如果在while(1)中再加一些其他的代码,漏字节的现象更严重了
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
我刚刚测了如果用的是原子内存管理的mallco,先分配了5K个节点的内存,再分配一个节点的内存,再去释放这一个节点的内存,这时候在内存管理表中寻找一个节点的可用内存去分配和释放肯定要很久了,但是分配这一个节点也只用了28us,释放的时间也不到1us,况且实际我用队列的时候队列中的数据肯定不会堆积到5K个节点这么多,这怎么解释呢?
一周热门 更多>