ios之庫Protobuf的使用


https://blog.csdn.net/dangbai01_/article/details/81099001

(1)Protobuf是什么?

Protobuf 即 google protocol buffer 是一種數據封裝格式協議,是google推出

的一種語言無關、平台無關、擴展性好的用於通信協議、數據存儲的結構化數據串行化方法。支持

C++、Python、Java三種語言。

 

 

(2)為什么要使用Protobuf?

在不同平台通信的時候,首先需要將對象進行序列化。iOS平台上我們常用NSKeyedArchiver進行

歸檔,當然也可以將數據處理為JSON或者XML格式。NSKeyedArchiver只能在iOS/Mac平台使用,

因此它歸檔的二進制數據不適合於在不同平台之間使用。JSON和XML雖然由於容易維護,易讀而應用

比較廣泛,但是對數據的利用效率都不是高。這時候該使用Protobuf了,因為Protobuf的優勢是

效率高,同樣的一份數據使用protobuf存儲的時候更小,更加方便

 

 

(3)安裝步驟如下:

一.安裝環境

        Pre:做這些事情的時候例行翻牆

    1.打開終端

    2.查看你的mac上是否安裝了brew

      $ brew -v

      Homebrew 1.6.8

      Homebrew/homebrew-core (git revision d822; last commit 2018-06-12)

     這是表明已經安裝,如果沒有安裝,使用下面的命令安裝下

 

   3.安裝brew (使用ruby安裝)

      $ ruby -e "$(curl -fsSL https://raw.githubusercontent.com/

   Homebrew/install/master/install)"

 

   4.下載依賴庫(工具)

       $ brew install automake

       $ brew install libtool

 

   5.下載Protobuf,這些執行之后后邊pod才能成功

       $ brew install protobuf

 

   6.克隆protobuf-objc,也就是說把代碼下載到本地

            方法一:

      $ cd desktop 我是clone到桌面,你們可以隨便放那

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

 

            方法二:我用的這種方法

            上邊的方法如果沒有成功,可以到官方網址下載https://github.com/google/protobuf/releases

            我下的版本是3.6.0,放在了桌面上

            

 

    7.運行腳本

        $  cd  Desktop     

        $  cd protobuf-3.6.0 切換到protobuf-3.6.0目錄下

 

        方法一:

        $  ./scripts/build.sh

 

        方法二:我用的這種方法

        $ ./autogen.sh

        $ ./configure

        $ make

        # 如果希望安裝protoc,執行下面的命令

        $ make install

 

        如果例行翻牆好像沒有出現錯誤,如果出現這樣的錯誤,不要慌,這是google自己版本的問題,我們不用管他,而且也不會像其他文章說的那

     樣,生成protoc-gen-objc這個插件,根本就不會生成,除非版本是2.6.0,這個問題采用下面的方式一樣能生成proto文件

 

      編譯后報錯:In file included from objc_helpers.cc:27:./google/protobuf/

     objectivec-descriptor.pb.h:17:2: error: This file was generated by

      an older version of protoc which is

      #error This file was generated by an older version of protoc which is

      ^

      ./google/protobuf/objectivec-descriptor.pb.h:18:2: error: incompatible with your

      Protocol Buffer headers. Please

    #error incompatible with your Protocol Buffer headers. Please

      ^

     ./google/protobuf/objectivec-descriptor.pb.h:19:2: error: regenerate this file

     with a newer version of protoc.

   #error regenerate this file with a newer version of proton.

    ......

 

 

二.生成后綴proto的文件

 

說明: 創建 proto 文件指定數據格式,可以選擇proto2和proto3格式,它們有些細微的區別,在生成代碼的時候會提示的,具體情況查看文檔Language Guide proto3。下面使用proto3格式,並且保存為person.proto。

  1.  創建文件person.proto

      $  cd desktop  我還是切換到桌面

      $  touch person.proto

  2. 編輯person.proto文件

      2.1 使用終端編輯

           $ vi person.proto

              syntax = "proto3";

              message Person{

              string name = 1;

               int32 age = 20;

             enum DeviceType{

                      iOS = 0;

                     Android = 1;

                  }

              }

        2.2 放到xcode中直接寫(推薦)

 

三.轉化成objc文件

由於我們生成不了protoc-gen-objc,因此使用

protoc --plugin=/usr/local/bin/protoc-gen-objc  --objc_out=./ person.proto

使用絕對路徑是不行的

 

我們使用 protoc 工具生成Objective-C代碼:

終端輸入: $ protoc --proto_path=A --objc_out=B person.proto

 

其中--proto_path=后跟A是需要處理的proto文件所在的文件夾,--objc_out=指明生成的是Objective-C代碼以及目標文件存放路徑,B是目標文件存放路徑,person.proto是需要處理的文件。

So:

我的做法是在桌面上建立兩個文件夾,一個叫protofile,一個叫objcfile

然后將創建好的person.proto放進protofile文件夾,然后

cd Desktop

在終端輸入:

protoc --proto_path=protofile --objc_out=objecfile person.proto 

然后成功在objcfile里得到我們要的 文件

 

 

導入工程中,這兩個文件是采用的手動引用計數,因此在加入項目后需要設置它們的編譯參數。

在工程target->Build Phrases->Compile Sources->給Person.pbobjc.m設置-fno-objc-arc.

 

 

設置

四.項目使用 (下載Protocol Buffers的源碼(下載地址),也可以到官網上下載)

1.使用cocoapods方式導入:我使用的是這種方法

    使用 pod  'Protobuf’  

    不能使用 pod 'ProtocolBuffers’,    

 

 

    使用 pod ‘ProtocolBuffers’的話:

    下載成功之后,編譯一看,結果報錯 

    #import "GPBProtocolBuffers_RuntimeSupport.h"無法找到

 

  原因是pods下來的是不帶GPB的,所以網上說的不對,應該是用

    pod 'Protobuf' ,這樣就沒有問題

2.靜態庫引入方式

     1.下載Protocol Buffers的源代碼

     2.工程里引入ProtocolBuffers_iOS.xcodeproj,或者編譯成靜態庫.a方式,然后公開頭文件(如圖2)

     3.設置依賴和連接庫。(如圖3)

     4.引入頭文件(如圖4)

 

 

圖2

 

圖3

 

 

圖4

五、具體使用和對比

設置依賴和連接庫。

引入頭文件開始使用。

#import "Person.pbobjc.h"

 

- (void)viewDidLoad {

    [super viewDidLoad];

 

    Person *person = [[Person alloc] init];

    person.name = @“qiao”;

    person.age = 18;

    NSData *data = [person data];

 

    NSLog(@"\nname:%@,age:%d", p.name, p.age);

}

 

打印結果如下:

2015-12-02 13:09:46.890 ProtobufDemo[34761:150533]

name:qiao,age:18

Protocol Buffer效率測試 我們這里說的效率是指空間占用率。簡單和JSON格式比較一下,同樣是存儲下面的信息: 

name: qiao

age:16

采用Protocol Buffers的數據大小為20個字節。而實用JSON存儲時,盡管我們將Key變成一個字節,如下:

NSDictionary *dict = @{@"n":@“qiao",

                       @“a":@“18",

                       };

NSData *jd = [NSJSONSerialization dataWithJSONObject:dict options:0 error:nil];

NSLog(@"jd: %lu", jd.length);

 

JSON數據還是占了36個字節,並且隨着可讀性提高,效率更低。XML就更不用說了。

總結

如果希望獲得更好的的可讀性,可以選用JSON和XML這類文本格式。但如果從數據效率上將,Protocol Buffer是一個不錯的選擇。存儲效率高,並且proto文件的可讀性和可維護性都比較強。

 

POST:

https://blog.csdn.net/diveinedu/article/details/50203033

https://www.jianshu.com/p/189368a9d744

https://blog.csdn.net/u014337888/article/details/78907625
---------------------
作者:當白
來源:CSDN
原文:https://blog.csdn.net/dangbai01_/article/details/81099001
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM