protobuf.js浏览器encode后得到uint8array,转化成的arraybuffer达到8192bytes
1.场景:利用protobuf.js库来对protocol buffer进行操作。
2.
首先是我的test.proto文件,用的是第三版的写法
读取proto文件的那些都已经操作好没有问题。
encode函数,对自定义的object进行编码。在浏览器端得到的是一个Uint8Array的数组
在浏览器下输出结果可以看到,得到的是一个只有11个字节的Uint8Array数组,但是转化成ArrayBuffer之后就变成了8192bytes
查阅了文档以及很多资料都没有结果,有dalao知道是什么情况吗……
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
遇到了同样的问题,研究了下,这样做即可
uint8.buffer.slice(uint8.byteOffset, uint8.byteOffset + uint8.byteLength);
请问楼主解决了吗?
把 Uint8Array 转成 ArrayBuffer,除非是传送通道不支持Uint8Array的时候(例如Kafka)才需要这么做。
转换:
arrayBuffer = Buffer.from(unit8Array.buffer)
一般情况encode得到Uint8Array之后直接向后传。后面结收到之后直接decode只用。
中间尽量不要做数据转换操作,因为转换太多,pb的序列化/反序列化速度快的优势就不存在了。
将
uint8.slice().buffer
发送给后端即可,slice() 方法会byteLength
自动截取有效的部分,也就是实际需要的数据。