?? google 开源的Protobuf,目的是解决json和xml在网络传输中占用带宽问题,它是二进制传输的,无论是解析性能还是占用网络带宽,都要比json和xml优越。
?? 但是,为什么protobuf没有取代json或者xml呢?觉得主要原因是protobuf 是二进制的,对调试不友好,出现问题,不好定位,所以很多公司不使用它。
? protobuf除了用作网络传输,还有另一个用途,就是用作配置文件。json也可以用作配置文件,但是json是明文,有些敏感信息容易泄露。protobuf的二进制可以派上用途,还可以把敏感信息隐藏,还有就是protobuf文件比较小。protobuf扩展性也是比较好的,可以在不影响原有字段的情况增加新的字段。
?? protobuf支持多种语言,我们在设备端使用,只用c++即可,其它语言可以不要,这样编译快一点。从github下载代码,解压,cd 到解压目录,执行. /autogen.sh , make 就可以了,然后到home目录下,修改 .profile, 把PATH路径指向 protoc? 所在目录,这样执行protoc? 命令,直接从命令行输入即可。
?? protoc? 编译好后,就可以用它来生成c++协议文件。首先定义好后缀为.proto文件,这个就是自己定义的协议,增加相应的字段就可以了,每个字段必须写上序号,如果是数组,就用 repeat声明。协议定义很简单的。
?? 协议定义好后,protoc? --cpp_out=.? my.proto生成c++实现文件,因为我们只要c++,所以只加了cpp_out参数,如果需要生成其它语言,增加相应的语言参数即可,生成实现文件后,就可以放到工程上用了,工作效率还是挺高的,不用自己写代码,就可以用作配置功能了。
?? protobuf可以直接从文件中解析数据,也可以从内存解析,网络上传输的数据,就用内存解析,我们在本地当配置文件使用,从文件解析即可。从项目使用效果来看,protobuf达到了我们的要求,性能,占用空间和扩展性都是不错的。
??
|