戴維營教育原創(chuàng)文章,轉載請注明出處。我們的夢想是做最好的iOS開發(fā)培訓!
成都創(chuàng)新互聯(lián)專注于網(wǎng)站建設|網(wǎng)站建設維護|優(yōu)化|托管以及網(wǎng)絡推廣,積累了大量的網(wǎng)站設計與制作經驗,為許多企業(yè)提供了網(wǎng)站定制設計服務,案例作品覆蓋PE包裝袋等行業(yè)。能根據(jù)企業(yè)所處的行業(yè)與銷售的產品,結合品牌形象的塑造,量身設計品質網(wǎng)站。在不同平臺通信的時候,首先需要將對象進行序列化。iOS平臺上我們常用NSKeyedArchiver
進行歸檔,當然也可以將數(shù)據(jù)處理為JSON或者XML格式。NSKeyedArchiver
只能在iOS/Mac平臺使用,因此它歸檔的二進制數(shù)據(jù)不適合于在不同平臺之間使用。JSON和XML雖然由于容易維護,易讀而應用比較廣泛,但是對數(shù)據(jù)的利用效率都不是高。Google提出了 Protocol Buffers 作為一種跨平臺、語言無關的序列化數(shù)據(jù)格式。Protocol Buffers提供代碼生成工具,能夠根據(jù)定義好的數(shù)據(jù)格式生成不同語言的代碼,然后集成到項目中使用。Protocol Buffers目前有兩種格式:proto2和proto3。Protocol Buffers支持Java、Python、C++、Objective-C等代碼的生成。
下載Protocol Buffers的源碼(下載地址),也可以到官網(wǎng)上下載。
編譯Protocol Buffers。雖然我們是可以直接將它的代碼或者項目引入Xcode中,但是還是需要編譯重要的代碼生成工具(protoc)。由于Protocol Buffers編譯時使用了autoconf/automake/libtool等UNIX工具,Mac可能沒有自帶,需要手動安裝。我們可以使用HomeBrew或者MacPort進行安裝(二選一就行)。
使用 HomeBrew 安裝:
$ brew install autoconf $ brew install automake $ brew install libtool
使用 MacPort 安裝:
$ sudo port install autoconf automake libtool
README.md中說可以直接用./configure
進行配置并編譯運行了,但實際還差一步,就是運行./autogen.sh
腳本,否則會發(fā)生錯誤。然而遺憾的是,autogen.sh中會下載https://googlemock.googlecode.com/files/gmock-1.7.0.zip。gmock處于 墻外 ,只能用×××出去?。]×××的可以找 戴維營教育 交流群免費索取,會不會被請喝茶?。?。
沒有運行autogen.sh的場景:
$ ./configure --with-protoc=protoc$ ./configure: line 2215: syntax error near unexpected token 'enable'$ ./configure: line 2215: 'AM_MAINTAINER_MODE(enable)'
一旦打開×××了,運行下面的腳本:
$ ./autogen.sh$ ./configure$ make# 如果希望安裝protoc,執(zhí)行下面的命令$ make install
創(chuàng)建 proto 文件指定數(shù)據(jù)格式,可以選擇proto2和proto3格式,它們有些細微的區(qū)別,在生成代碼的時候會提示的,具體情況查看文檔Language Guide proto3。下面使用proto3格式,并且保存為Person.proto。
syntax = "proto3"; message Person { string name = 1; int32 uid = 2; string email = 3; enum PhoneType { MOBILE = 0; HOME = 1; WORK = 2; } message PhoneNumber { string number = 1; PhoneType type = 2; } repeated PhoneNumber phone = 4; }
使用 protoc 工具生成Objective-C代碼。其中--proto_path=
后跟需要處理的proto文件所在的文件夾,--objc_out=
指明生成的是Objective-C代碼以及目標文件存放路徑,最后是需要處理的文件。
$ protoc --proto_path=. --objc_out=. Person.proto$ ls Person.pbobjc.h Person.pbobjc.m Person.proto
處理完成后,生成兩個文件,分別是 Person.pbobjc.h 和 Person.pbobjc.m 。這兩個文件是采用的手動引用計數(shù),因此在加入項目后需要設置它們的編譯參數(shù)。
為了方便管理,我們直接將Protocol Buffers中的iOS靜態(tài)庫項目引入進來。當然,如果喜歡用C++的話,可以直接將C++代碼導入項目,記得設置 Header Search Paths 或者 User Header Search Paths 。
設置依賴和連接庫。
引入頭文件開始使用。
#import "GPBProtocolBuffers.h" #import "Person.pbobjc.h" - (void)viewDidLoad { [super viewDidLoad]; Person *person = [[Person alloc] init]; person.name = @"Zhangsan"; person.email = @"diveinedu@qq.com"; person.uid = 23; NSData *data = [person data]; NSString *path = @"/Users/apple/Desktop/test.data"; [data writeToFile:path atomically:YES]; NSData *ldata = [NSData dataWithContentsOfFile:path]; Person *p = [Person parseFromData:ldata error:nil]; NSLog(@"\nname:%@\nemail:%@\nuid:%d", p.name, p.email, p.uid); }
打印結果如下:
2015-12-02 13:09:46.890 ProtobufDemo[34761:150533]name:Zhangsan email:diveinedu@qq.com uid:23
Protocol Buffer效率測試 我們這里說的效率是指空間占用率。簡單和JSON格式比較一下,同樣是存儲下面的信息:
name: Zhangsan email: diveinedu@qq.com uid: 23
采用Protocol Buffers的數(shù)據(jù)大小為30個字節(jié)。而實用JSON存儲時,盡管我們將Key變成一個字節(jié),如下:
NSDictionary *dict = @{@"n":@"Zhangsan", @"e":@"diveinedu@qq.com", @"u":@23};NSData *jd = [NSJSONSerialization dataWithJSONObject:dict options:0 error:nil];NSLog(@"jd: %lu", jd.length);
JSON數(shù)據(jù)還是占了46個字節(jié),并且隨著可讀性提高,效率更低。XML就更不用說了。
如果希望獲得更好的的可讀性,可以選用JSON和XML這類文本格式。但如果從數(shù)據(jù)效率上將,Protocol Buffer是一個不錯的選擇。存儲效率高,并且proto文件的可讀性和可維護性都比較強。
戴維營學院(高級開發(fā)視頻): http://v.diveinedu.com
潛心俱樂部(iOS面試必備): http://divein.club
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
文章標題:Protobuf在ios上的使用-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://jinyejixie.com/article22/ejocc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、靜態(tài)網(wǎng)站、品牌網(wǎng)站建設、ChatGPT、網(wǎng)站設計公司、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)