Protocol Buffer学习教程之开篇概述(一)
1. Protocol Buffer是什么
Protocol Buffer是google旗下的产品,用于序列化与反序列化数据结构,但是比xml更小、更快、更简单,而且能跨语言、跨平台。你可以把你的数据按你的要求结构化,然后可以转化成多种数据流,同时其他语言可以通过不同的流转化成自己熟悉的语言的数据格式。如C++语言开发者,定义了一个User数据结构,java开发者可以把此数据流轻易的转化成java环境下的数据结构。
我们知道json比xml更轻便,风闻json数据大小是xml的1/20,然后protobuf又是json的1/10,所以对数据大小要求高的选择protobuf合适;同时protobuff序列化与反序列化速度更快,所以对速度要求高的,可以选择protobuf;最关键一点,让我选择protobuf的原因是,它是向后兼容的,也就是说你可以对你的消息体进行修改,新旧版本之间相互兼容,而xml与json不容易做到这一点。
然后,protobuf的缺点是可读性差,不结合protobuf消息结构,是没办法读懂数据流的,这也是为获得轻便、高效做出的妥协。
2.它是如何工作的
它是怎么工作的呢,首先要把所有数据结构通过一个简单易懂的“.proto”文件定义,然后再把这个文件,通过Protocol buffer编译器编译成相应的类(C++、java、go等)文件。然后开发的时候,可以直接调用类文件中的接口,进行读、写、序列化与反序列化等操作。也就是说,首先它有一个任何语言开发者都易懂的规范文本(.proto),按此规范定义数据结构,然后用一个工具翻译成自己熟悉的语言的类文件,通过此类文件可以简单的操作数据。
3.如何学习protobuf
学习protobuf非常简单,首先你得学会写简单的“.proto”文件,也就是用protobuf语法描述你的数据结构,得先学习基本的protobuf语法,这样你就能定义自己的数据结构,所以我将在第二部分介绍protobuf的语法。其次,当你有自己的“.protobuf”文件后,你要把文件编译成你熟悉的开发语言(C++、java、python等)的数据结构类文件,所以你要一个编译器,在第三章节,我将介绍如何通过官方的源码获得编译器,然后如何把proto文件编译成C++类文件。最后,是如何利用生成的C++类文件,序列化与反序列化数据,与一些常用的方法与注意事项,将在最后一章节中介绍。
4.资源下载
官网首页(需要FQ)链接,最新稳定版本官方链接,各种历史版本官方链接,protocolbuffer有各种语言的版本,目前支持的语言有C、C++、java、python、C#、GO、js等语言。我们这里讲C++稳定版本v3.0.0,windows环境下的VC++开发。在以下链接中,找到“protobuf-cpp-3.0.0”,下载链接,proto规范官方介绍链接。
Protocol Buffer学习教程之开篇概述(一)的更多相关文章
- Protocol Buffer学习教程之编译器与类文件(三)
Protocol Buffer学习教程之编译器与类文件(三) 1. 概述 在前面两篇中,介绍了Protobuf的基本概念.应用场景.与protobuf的语法等.在此篇中将介绍如何自己编译protobu ...
- Protocol Buffer学习教程之类库应用(四)
Protocol Buffer学习教程之类库应用(四) 此教程是通过一个简单的示例,给C++开发者介绍一下如何使用protocol buffers编程,主要包括以下几部分: 定义一个.proto文件 ...
- Protocol Buffer学习教程之语法手册(二)
1.说明 此向导介绍如何使用protocol buffer language创建一个自己的protocolbuffer文件,包括语法与如何通过“.proto”文件生成数据访问的类,此处只介绍proto ...
- Protocol Buffers学习教程
最近看公司代码的过程中,看到了很多proto后缀的文件,这是个啥玩意?问了大佬,原来这是Protocol Buffers! 这玩意是干啥的?查完资料才知道,又是谷歌大佬推的开源组件,这玩意完全可以取代 ...
- Protocol Buffer学习笔记
Protocol Buffer Protobuf基础概念 Protobuf是google开发的数据结构描述语言,能够将结构化数据序列化与反序列化,取代json和xml,常用于服务器通信协议.RPC系统 ...
- 学习Google Protocol buffer之概述
XML这种属于非常强大的一种格式,能存储任何你想存的数据,而且编辑起来还是比较方便的.致命的缺陷在于比较庞大,在某些情况下,序列化和解析都会成为瓶颈.这种对于实时性很强的应用来说,就不太适合了,想象下 ...
- 学习Google Protocol buffer之语法
上一篇结尾的时候问了几个问题,其实主要就是这个protoBuffer协议的语法,弄清楚语法后边才好开展工作嘛,不然大眼而对小眼儿,互相不认识,就没法玩耍了.其实就是学习怎么用google提供的这套 p ...
- netty4与protocol buffer结合简易教程
各项目之间通常使用二进制进行通讯,占用带宽小.处理速度快~ 感谢netty作者Trustin Lee.让netty天生支持protocol buffer. 本实例使用netty4+protobuf-2 ...
- 【神经网络与深度学习】Google Protocol Buffer介绍
简介 什么是 Google Protocol Buffer? 假如您在网上搜索,应该会得到类似这样的文字介绍: Google Protocol Buffer( 简称 Protobuf) 是 Googl ...
随机推荐
- 在python 3.6的eclipse中,导入from lxml import etree老是提示,Unresolved import:etree的错误
支持代码运行没问题,暂时没有找到真正解决办法,只能通过一下办法暂时解决.如下图:
- python3 + selenium + eclipse 中报错:'chromedriver' executable needs to be in PATH. Please see https://sites.google.com/a/chromium.org/chromedriver/home
解决:提示chrome driver没有放置在正确的路径下,于是下载chrome dirver,然后放置到C:\Python36的目录下,再次运行就OK了!
- [poj3368]Frequent values(rmq)
题意:给出n个数和Q个询问(l,r),对于每个询问求出(l,r)之间连续出现次数最多的次数. 解题关键:统计次数,转化为RMQ问题,运用st表求解,注意边界. 预处理复杂度:$O(n\log n)$ ...
- [poj3071]football概率dp
题意:n支队伍两两进行比赛,求最有可能获得冠军的队伍. 解题关键:概率dp,转移方程:$dp[i][j] + = dp[i][j]*dp[i][k]*p[j][k]$表示第$i$回合$j$获胜的概率 ...
- K-S Test
K-S test, test for the equality of continuous, one-dimensional probability distribution that can be ...
- day1 java基础回顾-内省
为什么要学内省? 开发框架时,经常需要使用java对象的属性来封装程序的数据,每次都使用反射技术完成此类操作过于麻烦,所以sun公司开发了一套API,专门用于操作java对象的属性. 内省是用于操作j ...
- centos6.5安装FTP服务器
1.检测是否安装了FTP rpm -q vsftpd 2.安装ftp yum install vsftpd 3.完成ftp安装后,将 /etc/vsftpd/user_list 和 /etc/vsft ...
- matlab新手入门(二)(翻译)
矩阵和数组 MATLAB是“矩阵实验室”的缩写.虽然其他编程语言大多数一次使用数字,但MATLAB®主要用于整个矩阵和数组.所有MATLAB变量都是多维数组,无论数据类型如何.矩阵是通常用于线性代数的 ...
- 数据库路由中间件MyCat - 源代码篇(3)
此文已由作者张镐薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 2. 前端连接建立与认证 Title:MySql连接建立以及认证过程client->MySql:1.T ...
- Shader 模板缓冲和模板测试
http://blog.sina.com.cn/s/blog_6e159df70102xa67.html 模板缓冲的概念 Unity官方的Shader文档根本没有提到这个玩意,这个概念也是看到了UGU ...