在 ASIO 中使用 circle_buffer

问题描述

我知道很少有关于直接在 boost::asio async_read_some 中使用 circle_buffer 的帖子。它可能非常有效,因为您可以读取尽可能多的内容,然后开始解析并处理完整的消​​息(假设每条消息都有固定大小的标头、消息大小和消息字节)。如果最后有不完整的消息 - 只需执行另一个 async_read_some 并将新数据添加到最后。在这种情况下,您不需要管理剩余的数据。

问题是至少在 1.65 版本中,ASIO 不允许直接使用 circle_buffer。我知道有一种方法可以使用 array1() 和 array2() 函数(返回内部数组)并将它们提供给 ASIO,但我不明白它是如何工作的。 有什么线索吗? 谢谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...