经过资料收集,nanopb、protobuf-c、upb、pdb等均是采用Google的Protocol Buffers格式进行消息编解码的C语言库,根据项目的业务需求,我们决定采用nanopb进行数据数据的序列化。
之所以选择nanopb原因是其提供的编解码接口是通用的,如下面的编解码接口:
bool pb_encode(pb_ostream_t *stream, const pb_field_t fields[], const void *src_struct);bool pb_decode(pb_istream_t *stream, const pb_field_t fields[], void *dest_struct);
不像protobuf-c会为每个pb中的结构体单独生成编解码接口,nanopb采用了一个通用的编解码接口,只是第二个参数使用源或目标结构体的描述(该描述根据PB文件自动生成),就可以将第三个参数(结构体)编码或将数据填充到结构体中。
下面我们来分析一下,nanopb的整个处理流程: