本帖最后由 L1yp 于 2018-10-13 15:42 编辑
前言:
Protobuf解析目前圈子没见过一个能[一次解析全部节点]的模块(类似protoc.exe --decode_raw),一般都是解析最外一层,用过Protobuf的童鞋可能知道,在面对嵌套多层并节点很多的情况下,可能会有多层循环和很多个判断,我觉得这种写法极其恶心,所以我在想能不能像json解析那样,一次解析完全部节点,然后想取哪个就哪个,也不用多次解析. Protobuf生成也没见过一个好用的,谷歌的不知道怎么生成的,目前见到的都是复制很多次的打包,如果嵌套5层 最内层了10000字节,想象一下要拷贝几次,每次拷贝多大的内存.
思路:
解析思路:首先想到的是Protobuf结构可以用理解为树结构,这样就可以把个个节点保存在树上
生成思路:首先构造一棵树,然后计算所有类型为Length_delimited(2)的长度字段,然后就可以通过中序遍历树来打包protobuf结构,避免了多次复制内存.
实现:
首先Protobuf结构肯定是key-value-key-value...key-value
①如果类型是Varint(0),那么key-value对应的就是varint-varint
②如果是类型Length_delimited(2),对应的就是varint-varint(valueLen)-value
③其他类型和Varint类型类似
说不清楚的,略过
使用:
①解析Protobuf,如下图
③组包
欢迎加入ELib一起讨论:547525064
|