iOS 整合Protobuf,轉換proto檔案

來源:互聯網
上載者:User

標籤:objc   產生   typedef   user   art   開發環境   gpo   面向   bsp   

原文地址:http://blog.csdn.net/hyq4412/article/details/54891038

附加Homebrew安裝地址:https://brew.sh/index_zh-cn.html

 

Protobuf簡介

Protocol Buffer是google 的一種資料交換的格式,已經在Github開源,目前最新版本是3.1.0。它獨立於語言,獨立於平台。google 提供了多種語言的實現:Java、C#、C++、Go 和 Python,Objective-C,每一種實現都包含了相應語言的編譯器以及庫檔案。由於它是一種二進位的格式,比使用 XML 進行資料交換快許多。可以把它用於分布式應用之間的資料通訊或者異構環境下的資料交換。作為一種效率和相容性都很優秀的位元據傳輸格式,可以用於諸如網路傳輸、設定檔、資料存放區等諸多領域。

說明
  • protobuf3.0.0以上才官方支援Objective-C,低於3.0.0的請忽略或使用第三方轉換工具
  • 開發環境:32bit & 64bit iOS, 64bit OS X,Xcode7.0+
  • 基於效能原因沒有使用ARC,但可以被ARC代碼調用
步驟
  1. 轉換:將我們編寫好的XXX.proto檔案轉成Objective C檔案,也就是XXX.h和XXX.m檔案,轉換的工具是使用protoc這種二進位檔案來產生的,這檔案需要自己產生,稍後會介紹如何使用它來轉換Objective-C檔案
  2. 整合:如果在iOS項目中加入protobuf庫以及步驟1產生的OC檔案
轉換產生protoc

如果沒有裝autoconf automake libtool需要先裝這幾個,這裡使用brew來安裝,在shell執行 brew install autoconf automake libtool即可,如果沒有brew請自行先安裝brew。 
下載面向Objective-C的protobuf庫,地址為(https://github.com/google/protobuf/releases),要下載對應Objective-C的版本比如 protobuf-objectivec-3.1.0.zip,解壓。

cd到下載的目錄,依次執行:

  • $ ./autogen.sh
  • $ ./configure
  • $ make
  • $ make check
  • $ sudo make install

再執行 
- objectivec/DevTools/full_mac_build.sh

執行完後會看到src目錄下產生了protoc二進位檔案

使用protoc轉換

建立proto檔案,比如Person.proto

syntax = "proto3";message Person{     int32 age = 1;    string username = 2;    string phone = 3;}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

需要注意的是要指明proto的文法規則是proto2還是proto3。 
在src目錄(protoc所在目錄)執行

protoc --proto_path=... --objc_out=... XXX.proto
  • 1
  • 1

其中proto_path是我們建立的proto檔案所在目錄,objc_out為Objective-C檔案輸出路徑,XXX.proto是我們建立的proto檔案,可以一次轉換多個proto檔案,加在XXX.proto後面即可。

舉例:我們在src目錄下建立兩個檔案夾,gen和protocols檔案夾,gen為輸出目錄,protocols用於存放proto檔案,將建立的Person.proto放在protocols檔案夾下,執行命令

protoc --proto_path=protocols --objc_out=gen protocols/Person.proto
  • 1
  • 1

然後在gen檔案夾下就會產生Person.pbobjc.h和Person.pbobjc.m檔案。

整合

將產生的Ojective-C檔案(上面例子的Person.pbobjc.h和Person.pbobjc.m)放到項目中,如果項目使用了ARC,要將.m(例子的Person.pbobjc.m)的Complier Flags設為-fno-objc-arc。(protobuf基於效能原因沒有使用ARC)

加入protobuf庫,有兩種方式

  • 第一種是使用CocoaPods整合

    • 使用CocoaPods整合,有一個現成的pod可以使用–Protobuf,可以pod search Protobuf搜尋查看詳情,pod內容為 
      platform :ios, ‘7.1‘pod ‘Protobuf‘, ‘~> 3.1.0‘
      • 1
      • 2
      • 1
      • 2

    需要注意的是 platform :iOS, ‘7.1’ 
    7.1及以上才能匯入這個庫,這種方式優點是操作簡單,缺點是platform :ios, ‘7.1’ 要7.1或以上

  • 第二種是把相關檔案拖入項目中。

    • 拖入相關檔案到項目中,將objectivec檔案夾下的所有的.h檔案和.m檔案(除了GPBProtocolBuffers.m)(GPB開頭的那些檔案)以及整個google檔案夾add到項目中,如果項目中使用了ARC需要將以上所有.m檔案的的Complier Flags設為-fno-objc-arc。這種方法的優點是靈活性強,沒有7.1的束縛。缺點是操作麻煩點,如果用了ARC的話還要手動添加-fno-objc-arc(使用CocoaPods整合會自動添加),記得添加User Header Search Paths為$(PROJECT_DIR)/項目名/後接檔案地址 不然標頭檔會報錯
簡單使用

直接上代碼

- (void)viewDidLoad {[super viewDidLoad];Person *person = [[Person alloc] init];person.age = 100; person.username = @"huang";person.phone = @"10086";NSData *data = [person data];Person *p = [Person parseFromData:data error:nil];NSLog(@"person:%@",p);}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

iOS 整合Protobuf,轉換proto檔案

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.