Erik Bergstedt工具庫簡化在.NET中使用Protobuf的方式是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
我們提供的服務(wù)有:網(wǎng)站建設(shè)、成都做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、榆社ssl等。為近1000家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的榆社網(wǎng)站制作公司
Protobuf是由Google所創(chuàng)建的一種編碼格式,它的正式名稱叫做Protocol Buffers。這是一種緊湊的二進(jìn)制格式,它犧牲了內(nèi)容的可讀性與可擴展性,換來了更小的空間占用與更好的性能。為了對某個Protobuf消息進(jìn)行反序列化,客戶端與服務(wù)端必須事先對消息中的特定字段達(dá)成一致。(與XML或JSON格式相反,客戶端可以在運行時對后者的消息結(jié)構(gòu)進(jìn)行分析。)
.NET版本的Protobuf實現(xiàn)利用了屬性的自定義attribute,為每個屬性設(shè)置了一個“id”值。這些attribute將用于構(gòu)建包含Protobuf消息的二進(jìn)制數(shù)組。以下是Protobuf的一個應(yīng)用示例:
[ProtoContract] class Address { [ProtoMember(1)] public string Line1 { get; set; } [ProtoMember(2)] public string Line2 { get; set; } }
在C#中使用Protobuf的方式有些繁瑣,因為開發(fā)者需要對流(stream)進(jìn)行操作。而通過使用Erik Bergstedt所開發(fā)的Protobuffer庫,只需一行代碼就可以完成序列化或反序列化工作。
var serialize = _simpleSerializer.ToByteArray(GetPerson()); Person deserialize = _simpleDeserializer.FromByteArray(serialize);
開發(fā)者可能會感到疑惑,為什么不將這些API直接加入Protobuf項目中呢?Erik對此寫道:
因為這個庫的API是寫死的,它隱藏了某些功能,這對于某些場景來說可能并不合適。它為了換取簡便性而犧牲了某些功能。
舉例來說,在這個庫里對于流的創(chuàng)建方式是寫死的,并且對GZIP的支持也超出了原始的protobuf的功能范圍。
我們需要小心地區(qū)分特性與特性膨脹的區(qū)別。如果將這個庫的功能添加至原始的protobuf項目中,我會認(rèn)為它不是一種特性,而是一種特性膨脹。
Protobuffer是一個基于MIT協(xié)議的開源軟件。而Protobuf工具本身是由Google所開發(fā)的,它支持多種平臺與編程語言,包括C++、Java、JavaScript、Python和Ruby等等。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。