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