iOS之ProtocolBuffer搭建和示例demo

     這次搭建iOS的ProtocolBuffer編譯器和把*.proto源文件編譯成*.pbobjc.h 和 *.pbobjc.m文件時,碰到不少問題!

搭建pb編譯器到時沒有什麼問題,只是在把*.proto文件編譯出來後,我用cocoaPods集成ProtocolBuffers到自己項目,

cocoaPods集成的時候,我嘗試了兩個庫,一個是:

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff } span.s1 { }

https://github.com/google/protobuf.git,

另外一個是:

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff } span.s1 { }

https://github.com/alexeyxo/protobuf-objc.git

但是運行時都一直報錯通過:

一會報ProtocolBuffer庫文件找不到;

一會報版本不對:This file was generated by a different version of protoc which is incompatible with your Protocol Buffer library sources ;

一會報屬性數據格式不存在,不匹配。

   最後不得已只好放棄CocoaPods, 直接把從https://github.com/google/protobuf下載下來的庫拖進工程裏面,這樣才OK了!

簡單說下我這邊pb編譯器的安裝過程,和編譯後的使用demo:

一、環境安裝:pb編譯器的安裝

     1、從https://github.com/google/protobuf/releases下載protocolBuffer對應版本編譯器包,比如目前的對應的objc最新版本

    下載地址爲:https://github.com/google/protobuf/releases/download/v3.1.0/protobuf-objectivec-3.1.0.zip

  2、解壓包,假設解壓後的文件夾名爲: protobuf-objectivec-3.1.0,     打開終端,進入文件夾protobuf-objectivec-3.1.0, 依次執行以下命令:

./configure
make
make check
sudo make install

  如果編譯順利的話,便可以使用protoc命令了,以後便可以用這個命令將.proto文件轉換爲不同語言的源代碼文件。

二、創建新項目,導入pb庫,編寫proto文件編譯,使用過程       1、從https://github.com/google/protobuf.git下載源碼,解壓,裏面有支持不同語言的版本源碼,

  我們只需要裏面的支持objc的文件夾名爲:objectivec,如圖:

  2、新建一個工程命名爲Tan_ProtocolBuffer,創建一個文件夾,假設命名爲:protocolbuf, 把第一步的pb源碼複製到此文件夾中:

  3、使用Xcode打開工程,點擊左下角“+”, 引用protocolBuffer源文件到工程中

(源文件裏面有兩個工程配置文件:ProtocolBuffers_iOS.xcodeproj和ProtocolBuffers_OSX.xcodeproj,引用ProtocolBuffers_iOS.xcodeproj就好)

  4、選中工程: targets —>  Build Phases  —>  Link Binary With Libraries, 引用源碼靜態庫文件:libProtocolBuffers.a

  5、在工程設置搜索靜態庫的頭文件(pb文件在protocolbuf文件夾裏面):

   targets —>  Build Setting  —>  Search Paths  —> Header Search Paths, 寫入:$(PROJECT)/protocolbuf 

  6、編寫測試文件*.proto,比如新建一個文件Person.proto, 按照官方標準語法https://developers.google.com/protocol-buffers/ 編寫通用代碼,   寫好後在終端進入該Person.proto文件所在目錄,使用protoc命令:protoc *.proto --objc_out=../Pro_out 進行編譯。   把Person.proto文件編譯成Person.pbobjc.h和Person.pbobjc.m, 生成的文件在Pro_out文件夾裏面。   如果Person.proto源文件有語法問題,編譯時會報錯;當編譯時什麼提示都沒有,表示編譯成功:   將編譯好的*.pbobjc.h和*.pbobjc.m拖入工程中,因爲不支持arc, 所以需要在*.pbobjc.m設置-fno-objc-arc, 然後就可以使用了。

  截圖如下:  

  7、編寫測試代碼,使用Person類進行數據序列化和反序列:

示例demo下載地址:https://github.com/xiaotanit/Tan_ProtocolBuffer

原文鏈接:http://www.cnblogs.com/tandaxia/p/6181534.html

關於使用GCDAsyncSocket 和 Protobuf開發中碰到的拆包和粘包問題,見我的下一篇文章:

CocoaAsyncSocket + Protobuf 處理粘包和拆包問題

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #822d0f } span.s1 { }

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