ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

如何使用C#使用Protobuf进行非阻塞套接字读取?

2019-05-17 10:55:09  阅读:240  来源: 互联网

标签:c async-await nonblocking protocol-buffers


假设我想从网络套接字执行非阻塞读取.
我可以异步等待套接字读取x字节,一切都很好.

但是如何通过protobuf将其与反序列化相结合?

从流中读取对象必须阻塞?也就是说,如果流包含的解析器数据太少,那么必须在后台进行一些阻塞,以便读者可以获取所需的所有字节.

我想我可以使用lengthprefix分隔符并读取第一个字节,然后计算出在解析之前我必须获取的最小字节数,这是正确的方法吗?
例如如果我的缓冲区是500字节,则等待那500个字节,并解析长度前缀,如果长度超过500,则再次等待,直到读取所有内容.

结合非阻塞IO和protobuf解析的惯用方法是什么?

(我现在正在使用Jon Skeet的实施http://code.google.com/p/protobuf-csharp-port/)

解决方法:

作为一般规则,序列化程序通常不包含DeserializeAsync方法,因为这真的很难(至少,有效).如果数据大小适中,那么我建议使用异步代码缓冲所需的数据量 – 然后在所有必需数据可用时进行反序列化.如果数据非常大并且您不希望缓冲内存中的所有内容,那么请考虑在工作线程上使用常规同步反序列化.

(请注意,这是特定于实现的,但如果您使用的序列化程序确实支持异步反序列化:那么确定,使用它)

标签:c,async-await,nonblocking,protocol-buffers
来源: https://codeday.me/bug/20190517/1120569.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有