ProtoBuf簡(jiǎn)介
Protocol Buffer的簡(jiǎn)稱。Google旗下的一款平臺(tái)無(wú)關(guān),語(yǔ)言無(wú)關(guān)吼旧,可擴(kuò)展的序列化結(jié)構(gòu)數(shù)據(jù)格式,適合用于數(shù)據(jù)存儲(chǔ)未舟,作為不同應(yīng)用圈暗、語(yǔ)言之間相互通信的數(shù)據(jù)交換格式,序列化后的數(shù)據(jù)為二進(jìn)制數(shù)據(jù)(pb格式的數(shù)據(jù)),類比XML裕膀、JSON员串。本文記錄的是ProtoBuf在iOS平臺(tái)oc語(yǔ)言的使用,ProtoBuf3.0.0以上才官方支持Objective-C昼扛,低于3.0.0的請(qǐng)忽略或使用第三方轉(zhuǎn)換工具寸齐,并且基于性能原因沒有使用ARC,但可以被ARC代碼調(diào)用抄谐。
Objective-C的protobuf庫(kù)渺鹦,下載地址為
https://github.com/google/protobuf/releases
使用流程:
轉(zhuǎn)換:使用轉(zhuǎn)換的二進(jìn)制工具protoc,將XXX.proto文件轉(zhuǎn)成Objective C文件斯稳,即XXX.h和XXX.m文件海铆。
集成:在iOS項(xiàng)目中加入protobuf庫(kù)以及上述生成的OC文件
集體步驟:
1.生成protoc
如果沒有裝autoconf automake libtool需要先裝這幾個(gè),這里使用brew來(lái)安裝挣惰,在shell執(zhí)行 brew install autoconf automake libtool即可卧斟,如果沒有brew請(qǐng)自行先安裝brew。 cd進(jìn)入已下載的protobuf庫(kù)文件下憎茂,執(zhí)行以下命令:
./autogen.sh
./configure
make
make check
sudo make install
再執(zhí)行 :
./objectivec/DevTools/full_mac_build.sh
執(zhí)行完后會(huì)看到src目錄下生成了protoc二進(jìn)制文件
注意:cd進(jìn)入已下載的protobuf庫(kù)文件路徑不要用空格珍语,libtool無(wú)法識(shí)別路徑中的空格,make會(huì)失敗竖幔。本人踩過的坑板乙,浪費(fèi)時(shí)間。
2.使用protoc轉(zhuǎn)換
創(chuàng)建proto文件,比如Student.proto
syntax = "proto3";
message Student
{
required int32 age = 1;
required string name = 2;
optional string address = 3;
}
在src目錄(protoc所在目錄)執(zhí)行
protoc --proto_path=... --objc_out=... XXX.proto
其中proto_path是創(chuàng)建的proto文件所在目錄募逞,objc_out為Objective-C文件輸出路徑,XXX.proto是創(chuàng)建的proto文件蛋铆,可以一次轉(zhuǎn)換多個(gè)proto文件,加在XXX.proto后面即可放接。
如:protoc --proto_path=/Users/admin/Desktop/src --objc_out=/Users/admin/Desktop/dist Student.proto
3.集成
將生成的Ojective-C文件(上面例子的Student.pbobjc.h和Student.pbobjc.m)放到項(xiàng)目中刺啦,如果項(xiàng)目使用了ARC,要將.m(例子的Student.pbobjc.m)的Complier Flags設(shè)為-fno-objc-arc。(protobuf基于性能原因沒有使用ARC)
加入protobuf庫(kù)纠脾,有兩種方式
第一種是使用CocoaPods集成玛瘸。
使用CocoaPods集成,有一個(gè)現(xiàn)成的pod可以使用–Protobuf,可以pod search Protobuf搜索查看詳情苟蹈,pod內(nèi)容為
platform :ios, '7.1'
pod 'Protobuf', '~> 3.1.0'
需要注意的是 platform :ios, ‘7.1’
7.1及以上才能導(dǎo)入這個(gè)庫(kù),這種方式優(yōu)點(diǎn)是操作簡(jiǎn)單糊渊,缺點(diǎn)是platform :ios, ‘7.1’ 要7.1或以上
第二種是把相關(guān)文件拖入項(xiàng)目中。
拖入相關(guān)文件到項(xiàng)目中慧脱,將objectivec文件夾下的所有的.h文件和.m文件(除了GPBProtocolBuffers.m)(GPB開頭的那些文件)以及整個(gè)google文件夾add到項(xiàng)目中渺绒,如果項(xiàng)目中使用了ARC需要將以上所有.m文件的的Complier Flags設(shè)為-fno-objc-arc。這種方法的優(yōu)點(diǎn)是靈活性強(qiáng)磷瘤,沒有7.1的束縛芒篷。缺點(diǎn)是操作麻煩點(diǎn),如果用了ARC的話還要手動(dòng)添加-fno-objc-arc(使用CocoaPods集成會(huì)自動(dòng)添加)
簡(jiǎn)單使用采缚,示例代碼:
- (void)viewDidLoad {
[super viewDidLoad];
Student *student = [[Student alloc] init];
student.age = 18;
student.name = @"XiaoMing";
student.address = @"Beijing";
NSData *data = [student data];
NSLog(@"序列化:%@",data);
Student *s = [Student parseFromData:data error:nil];
NSLog(@"反序列化:%@",s);
}