Protobuf介绍

今天突然换了个项目T_T,本来就是刚来什么都不是很熟悉,不过这样也好技术提高快。
这个项目公司用的是 ssh + protobuf,研究到现在总算基本的会使用protobuf了,先不管怎么用,先把这个框架是什么记录下来。

protobuf简介

1、protobuf是什么

protobuf是google出的一个开源序列化框架,类似于XML、JSON 这样的数据表示语言,其最大的特点是基于二进制,因此比传统的一些XML表示的效率要高出不少。
虽然protobuf是二进制的数据格式,但是并没有因为这样变得复杂,我们可以通过它的语法来定义结构化的消息格式,然后根据命令行工具生成相关的类,支持的语言有java、C++、Python等语言。把这些类放在项目里面,就可以调用相关方法来完成业务消息的序列化和反序列化的工作。

protobuf在google中是一个比较核心的基础库,作为分布式运算涉及到大量的不同业务消息的传递,如何高效简洁的表示、操作这些业务消息在google这样的大规模应用中是至关重要的。而protobuf这样的库正好是在效率、数据大小、易用性之间取得了很好的平衡。 ——来自网上

2、protobuf的优点

1,性能好,效率高,二进制的格式

2,代码生成机制,数据解析类自动生成,自动生成相关类

3,支持向后兼容和向前兼容
(所谓的“向后兼容”(backward compatible),就是说,当模块B升级了之后,它能够正确识别模块A发出的老版本的协议。由于老版本没有“状态”这个属性,在扩充协议时,可以考 虑把“状态”属性设置成非必填 的,或者给“状态”属性设置一个缺省值
  所谓的“向前兼容”(forward compatible),就是说,当模块A升级了之后,模块B能够正常识别模块A发出的新版本的协议。这时候,新增加的“状态”属性会被忽略。)
4,支持多种编程语言(java,c++,python)

3、protobuf的缺点

1,应用不够广,protobuf刚公布没多久,如果你的系统需要提供若干对外的接口给第三方系统调用,最好不要使用。
2,二进制格式导致可读性差,为了提高性能,protobuf采用了二进制格式进行编码。这直接导致了可读性差的问题
3,缺乏自描述(一般来说,XML是自描述的,而protobuf格式则不是。给你一段二进制格式的协议内容,如果不配合相应的proto文件,根本不知道写的是什么……)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值