欢迎来到天天文库
浏览记录
ID:22372587
大小:59.00 KB
页数:6页
时间:2018-10-28
《the principle and application of protocol buffer》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、ThePrincipleandApplicationofProtocolBufferThePrincipleandApplicationofProtocolBufferLUZhong-yangGUOZhen-bo(CollegeofInformationEngineering,QingdaoUniversity,QingdaoShandong266071,China)【Abstract】Thispapermainlyintroducestheprincipleofprotobufandconsidersitspressionefficiencyandthespeedofdataparsin
2、g.Thesimulationresultsrevealthat,paredlandjson,protobufhasthesamllestsizeofserializedfileandthefastestspeedofparsing.Therefore,oresuitableforsomeapplicationsrequiringhighperformance.【KeyeprovidedbyGoogle[1].Throughtheprotopiler,userscanpilethe.protofiletogeneratethecorrespondingclass,andthencallth
3、ecorrespondingmethodsintheclasstoserializeanddeserializethemessage.Java,c++andpythonarethreekindsoflanguageprovidedbyGoogle,landjson[2]andthecontentsofserializeddatatransferformatisbinary.Besides,protobufcanbeusedfordataexchangebetent,distributedapplicationofdatamunicationanddatastorageandconfigur
4、ationfilesandotherfields.Protobufisakindofprotocolmailyusedforobjectserializationandbinarycoding.Sincetheunderlyingmunicationprotocolisgeneralbinaryformat,ptotobufhastheadvantagesofsmalloccupiedspaceinthemunicationunicationis:protobufpacksthetransferingdataaccordingtothedefinedformatofmessageandth
5、eserilizesthemessagebeforesendingdata;thenitdeserilizesthepackagesatthereceivingside.2DesignaprotobuffileGenerally,essageformatandusingprotoasasuffixThedefinitionofthemessageformatisverysimple,andeachfieldhasatag,modifier(repeated/required/optional)andfieldtype(bool/bytes/string/int32/long)[3].The
6、valueoftherequiredfieldmustbeinitialized,otherakemistakesthatserializationanddeserializationarepiledunderthelibraryofDebugmode.Foroptionalfield,itployrepeatedfieldtodefinethatapersonultiplemobilephones.Thefunctionoftagistoidentifythepositionsofthefieldsinthebinarystream.Theformatofprotofileisdefin
7、edasbeloessageuser{requiredstringname=1;requiredint32age=2;};(2)Generatingcodefilesaticallygeneratedbytheprotopiler[4],essageformatnaspecifictoserializetheusermessagetoafile.AndtheotherisaJavaprogram,afile.Figure
此文档下载收益归作者所有