Protobuf詳解

【轉載】Protobuf詳解

按:

新公司前端後端,使用的數據化方式是protobuf (Protocol Buffer)。

 

一,什麼是Protobuf

官方文檔給出的是:

a language-neutral, platform-neutral, extensible way of serializing structured data for use in communications protocols, data storage, and more.

 

二,Protobuf的優點

1,性能好,效率高


2,代碼生成機制,數據解析類自動生成


3,支持向後兼容和向前兼容


4,支持多種編程語言(java,c++,python)


5,參考文檔:http://blog.csdn.net/caisini_vc/article/details/5599468

 

三,Protobuf的缺點

1, 應用不夠廣


2, 二進制格式導致可讀性差(二進制格式)


3, 缺乏自描述

官方文檔描述如下:for instance, protocol buffers would not be a good way to model a text-based document with markup (e.g. HTML), since you cannot easily interleave structure with text


4, 參考文檔:http://blog.csdn.net/caisini_vc/article/details/5599468

 

四,Protobuf環境的搭建

步驟:

1, 安裝maven

http://blog.csdn.net/jiangguilong2000/article/details/9284437


2, 下載probuf源碼和編譯器

http://blog.csdn.net/jiangguilong2000/article/details/9284297


3, 拷貝文件,執行相應mvn install命令。 (protobuf並不提供jar包,需要自己執行命令生成)

Note:

在這個地方遇到了一個問題,錯誤信息如下:

Failed to execute goal org.apache.maven.plugins:maven-antrun-plugin:1.3:run (generate-sources) on project protobuf-java: An Ant BuildException has occured: Execute failed: java.io.IOException: Cannot run program "..\src\protoc": CreateProcess error=2, ????????? ->

原因:犯了了一個很2的問題,拷貝protoc.exe文件的路徑拷錯了。請詳細比較步驟2中的路徑,一定拷對路徑。


4,通過protoc.exe編譯addressbook.proto文件

http://blog.sina.com.cn/s/blog_653ac36d0101h9kn.html

 

五,核心概念

1,.proto文件

相當於確定數據協議,數據結構中存在哪些數據,數據類型是怎麼樣


2,modifiers

2-1 required 不可以增加或刪除的字段,必須初始化

2-2 optional 可選字段,可刪除,可以不初始化

2-3 repeated 可重複字段, 對應到java文件裏,生成的是List


3,Message

在proto文件裏,數據的協議時以Message的形式表現的。


4, Build

生成具體的java類時,例如Person.java,同時會存在build方法。文檔的意思是對於轉化後的數據,具有唯一性,build提供了便利的方法來初始化這些數據。

 

六,其他

暫無


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章