Java序列化机制是一项非常有用的技术,但Java本身的序列化机制是否一定是最好的呢?对比几种不同的将Java简单对象序列化的结果是一件很有趣的事情。本文笔者以Java序列化,JSON序列化,Google ProtoBuf序列化三种方式来进行对比。测试结果表明,对于简单的Java对象,Google ProtoBuf的序列化速度几乎是Java序列化的2倍。而通过JSON-lib实现的JSON序列化速度也快不到哪里去。(该测试结果源自TSS,先不就其权威性进行评论,根据个人经验,Google ProtoBuf序列化之后的对象字符串的长度很短,但使用Java序列化之后的对象字符串的长度是难以想象的,如果对象足够大,经常会出现浏览器URL过长无法解析的问题,从这点上来看,Google ProtoBuf是个提高效率的不错选择)
下面是测试结果,时间越短的越好:
// =========// Java Serialization...............:2135 // JSON Serialization...............:20523 // Google ProtoBuf Serialization....:1472 // ========= ==============================
[ad#468-60]