这篇博客主要对Xml,Json,Hessian,Protocol Buffers的序列化和反序列化性能进行对比,Xml和Json的基本概念就不说了。
Hessian:Hessian是一个轻量级的remoting onhttp工具,提供了RMI的功能,采用的是二进制RPC协议,内置了序列化功能。
Protocol Buffers:google的一种数据交换的格式,它独立于语言,由于它是一种二进制的格式,比使用 xml 进行数据交换快许多,可以把它用于分布式应用之间的数据通信或者异构环境下的数据交换。作为一种效率和兼容性都很优秀的二进制数据传输格式,可以用于诸如网络传输、配置文件、数据存储等诸多领域。Google提供了Java、C++、Python的实现,现在网上也已经有了c#等语言的实现。
XML:使用.Net自带的XmlSerializer。
Json:使用的是ServiceStack.Text,性能高于Newtonsoft.Json,但是速度最快的应该是fastJSON.net。
Hessian:使用的是HessianCSharp库, 从nuget上下载。
Protocol Buffers:使用的是protobuf-net,从nuget上下载。
下列是测试使用的实体。
[ProtoContract] public class Student { [ProtoMember(1, IsRequired = true)] public int Id { get; set; } [ProtoMember(2, IsRequired = true)] public string Name { get; set; } [ProtoMember(3, IsRequired = true)] public DateTime Time { get; set; } [ProtoMember(4, IsRequired = true)] public List<string> Books { get; set; } } Student student = new Student() { Id = 1, Name = "Alan", Time = DateTime.Now, Books = new List<string>() { "语文", "数学" } };