微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

高效的C#字节队列,用于解析二进制消息包的字节流

我正在尝试替换通常实现的循环缓冲区.队列的功能是缓冲传入的字节(例如从串行端口或其他数据流),而解析器检查队列中的字节并检测并提取消息数据包.

标准:

>可以成长(即不固定大小)
>

= 1 bytes can be enqueued at a time

>

= 1 bytes can be dequeued at a time

>高效

我只是想使用它

System.Collections.Generic.Queue<byte>

…但我不知道这是否是最有效的使用类型.有什么建议么?

有什么更聪明的方式做我想做的事情吗? (例如有趣的建议here)

感谢您的建议和输入.

Prembo.

解决方法

队列<字节>由字节[]支持,但是如果使用Array.copy从底层缓冲区复制,而不是循环通过Enqueue / Dequeue方法,则会看到更好的性能.因此,如果Queue< byte>不给你想要的性能,那么你可以实现自己的队列类,它提供了QueueMultiple和DequeueMultiple方法.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐