Protobuf

一,什麼是Protobufhtml

官方文檔給出的是:java

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

 

二,Protobuf的優勢c++

1,性能好,效率高apache

 

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

 

3,支持向後兼容和向前兼容數據結構

 

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

 

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提供了便利的方法來初始化這些數據。

相關文章
相關標籤/搜索