Java序列化与JSON序列化大比拼

一、背景

成都创新互联专业为企业提供杨浦网站建设、杨浦做网站、杨浦网站设计、杨浦网站制作等企业网站建设、网页设计与制作、杨浦企业网站模板建站服务,十载杨浦做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

有项目需要传输Map结构的数据,有人倾向用Java序列化来做,有人倾向用JSON的序列化来做。所以我们还是比比吧。

Java观点:Object2Object,使用时简单快速。

JSON观点:JSON格式与语言无关,扩展性强,速度也应该不慢。

大家可能对Java序列化都有一个错误的认识,认为Java序列化比JSON的序列化效率高并且序列化的数据小,其实实际上并不一定是这样,我这次就想通过实际测试来解开这个谜团。

二、测试方式

测试同一个Map并序列化为byte[],并再将byte[]反序列化为 Map的过程。Object中包括 String,Integer,Long,Boolean,Float,Double常规类型的数据。

序列化:Map -> byte[]

反序列化:byte[] -> Map

测试各种大小不同的Map,并循环执行同一操作N次,来得到一个相对稳定的线性结果。

三、比较的对象

JAVA:

手写Java(1.6.0_32)与Common Lang3(3.1)的SerializationUtils。

JSON:

将采用Gson(2.2.2)与json-smart(2.0-RC2)两种不同的JSON解析器。json-smart号称是速度最快的JSON解析器。

四、比较结果

Map大小(10-100)循环10万次

序列化时间比较(y为序列化时间ms)

反序列化时间比较(y为反序列化时间ms)

序列化时间汇总比较(y为序列化与反序列化总时间ms)

序列化后byte大小比较(由于同类线重合显示为2条线)

Map大小(100-1000)循环1万次

序列化时间比较(y为序列化时间ms)

反序列化时间比较(y为反序列化时间ms)

序列化时间汇总比较(y为序列化与反序列化总时间ms)

序列化后byte大小比较(由于同类线重合显示为2条线)

比较总结

Map在小于100时:

Java的反序列化时的性能要比Java序列化时性能差很多,1.5倍左右差距。

JSON序列化性能明显由于Java序列化性能,尤其是反序列化过程。并且序列化后的数据大小也是JSON格式的小。

Map在大于100小于1000时:

Java的反序列化时的性能并没有随Map的大小变化而变差。

JSON阵营中Gson在序列化过程中,比Java只快了那么一点点。在反序列化过程中Gson开始领先与Java,但在Map的大小过700多以后,Gson的反序列化性能比Java要慢。但JSON阵营中的json-smart依然表现出色完全是两个级别。

并不是Java的序列化速度总是最快体积最小,Java需要考虑对象类型,属性类型与内部对象信息等一系列对数据本身并不相关的内容的处理。JSON以固定的格式,稳定简单的数据结构大大简化了序列化过程,虽然也要创建新的Java数据对象但并不会比Java反序列化的速度慢。

从测试结果上看JSON的json-smart更适合项目的需要。

#p#

五、测试代码源码

SerializationTest接口

 
 
 
 
  1. package org.noahx.javavsjson;  
  2.  
  3. import java.util.Map;  
  4.  
  5. /**  
  6.  * Created with IntelliJ IDEA.  
  7.  * User: noah  
  8.  * Date: 3/8/13  
  9.  * Time: 9:59 PM  
  10.  * To change this template use File | Settings | File Templates.  
  11.  */ 
  12. public interface SerializationTest {  
  13.  
  14.     public String getTestName();  
  15.  
  16.     public Map testBytes2Map(byte[] bytes);  
  17.  
  18.     public byte[] testMap2Bytes(Map map);  
  19. }  

JavaSerializationTest

 
 
 
 
  1. package org.noahx.javavsjson;  
  2.  
  3. import java.io.*;  
  4. import java.util.Map;  
  5.  
  6. /**  
  7.  * Created with IntelliJ IDEA.  
  8.  * User: noah  
  9.  * Date: 3/8/13  
  10.  * Time: 10:05 PM  
  11.  * To change this template use File | Settings | File Templates.  
  12.  */ 
  13. public class JavaSerializationTest implements SerializationTest {  
  14.  
  15.     @Override 
  16.     public String getTestName() {  
  17.         return "Java";  
  18.     }  
  19.  
  20.     @Override 
  21.     public Map testBytes2Map(byte[] bytes) {  
  22.         Map result = null;  
  23.         try {  
  24.             ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(bytes);  
  25.             ObjectInputStream inputStream = new ObjectInputStream(byteArrayInputStream);  
  26.  
  27.             result = (Map) inputStream.readObject();  
  28.             inputStream.close();  
  29.         } catch (ClassNotFoundException e) {  
  30.             e.printStackTrace();  
  31.         } catch (IOException e) {  
  32.             e.printStackTrace();  
  33.         }  
  34.  
  35.         return result;  
  36.     }  
  37.  
  38.     @Override 
  39.     public byte[] testMap2Bytes(Map map) {  
  40.         byte[] bytes = null;  
  41.         try {  
  42.             ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();  
  43.             ObjectOutputStream outputStream = new ObjectOutputStream(byteArrayOutputStream);  
  44.  
  45.             outputStream.writeObject(map);  
  46.             outputStream.close();  
  47.  
  48.             bytes = byteArrayOutputStream.toByteArray();  
  49.         } catch (IOException e) {  
  50.             e.printStackTrace();  
  51.         }  
  52.         return bytes;  
  53.     }  
  54. }  

CommonLang3SerializationTest

 
 
 
 
  1. package org.noahx.javavsjson;  
  2.  
  3. import org.apache.commons.lang3.SerializationUtils;  
  4. import java.io.Serializable;  
  5. import java.util.Map;  
  6.  
  7. /**  
  8.  * Created with IntelliJ IDEA.  
  9.  * User: noah  
  10.  * Date: 3/9/13  
  11.  * Time: 2:24 AM  
  12.  * To change this template use File | Settings | File Templates.  
  13.  */ 
  14. public class CommonLang3SerializationTest implements SerializationTest {  
  15.     @Override 
  16.     public String getTestName() {  
  17.         return "Commons Lang3";  
  18.     }  
  19.  
  20.     @Override 
  21.     public Map testBytes2Map(byte[] bytes) {  
  22.         return (Map) SerializationUtils.deserialize(bytes);  
  23.     }  
  24.  
  25.     @Override 
  26.     public byte[] testMap2Bytes(Map map) {  
  27.         return SerializationUtils.serialize((Serializable) map);  
  28.     }  
  29. }  

GsonSerializationTest

 
 
 
 
  1. package org.noahx.javavsjson;  
  2.  
  3. import com.google.gson.Gson;  
  4. import java.io.UnsupportedEncodingException;  
  5. import java.util.Map;  
  6.  
  7. /**  
  8.  * Created with IntelliJ IDEA.  
  9.  * User: noah  
  10.  * Date: 3/8/13  
  11.  * Time: 10:02 PM  
  12.  * To change this template use File | Settings | File Templates.  
  13.  */ 
  14. public class GsonSerializationTest implements SerializationTest {  
  15.  
  16.     private Gson gson;  
  17.  
  18.     public GsonSerializationTest() {  
  19.         gson = new Gson();  
  20.     }  
  21.  
  22.     @Override 
  23.     public String getTestName() {  
  24.         return "Gson";  
  25.     }  
  26.  
  27.     @Override 
  28.     public Map testBytes2Map(byte[] bytes) {  
  29.         Map result = null;  
  30.         try {  
  31.             result = gson.fromJson(new String(bytes, "UTF-8"), Map.class);  
  32.         } catch (UnsupportedEncodingException e) {  
  33.             e.printStackTrace();  
  34.         }  
  35.         return result;  
  36.     }  
  37.  
  38.     @Override 
  39.     public byte[] testMap2Bytes(Map map) {  
  40.         String str = gson.toJson(map);  
  41.         byte[] bytes = null;  
  42.         try {  
  43.             bytes = str.getBytes("UTF-8");  
  44.         } catch (UnsupportedEncodingException e) {  
  45.             e.printStackTrace();  
  46.         }  
  47.         return bytes;  
  48.     }  
  49. }  

JsonSmartSerializationTest

 
 
 
 
  1. package org.noahx.javavsjson;  
  2.  
  3. import net.minidev.json.JSONObject;  
  4. import net.minidev.json.JSONValue;  
  5. import net.minidev.json.parser.ParseException;  
  6. import java.io.UnsupportedEncodingException;  
  7. import java.util.Map;  
  8.  
  9. /**  
  10.  * Created with IntelliJ IDEA.  
  11.  * User: noah  
  12.  * Date: 3/9/13  
  13.  * Time: 1:30 AM  
  14.  * To change this template use File | Settings | File Templates.  
  15.  */ 
  16. public class JsonSmartSerializationTest implements SerializationTest {  
  17.     @Override 
  18.     public String getTestName() {  
  19.         return "Json Smart";  
  20.     }  
  21.  
  22.     @Override 
  23.     public Map testBytes2Map(byte[] bytes) {  
  24.         Map map = null;  
  25.         try {  
  26.             map = (Map) JSONValue.parseStrict((new String(bytes, "UTF-8")));  
  27.         } catch (ParseException e) {  
  28.             e.printStackTrace();  
  29.         } catch (UnsupportedEncodingException e) {  
  30.             e.printStackTrace();  
  31.         }  
  32.         return map;  
  33.     }  
  34.  
  35.     @Override 
  36.     public byte[] testMap2Bytes(Map map) {  
  37.         String str = JSONObject.toJSONString(map);  
  38.         byte[] result = null;  
  39.         try {  
  40.             result = str.getBytes("UTF-8");  
  41.         } catch (UnsupportedEncodingException e) {  
  42.             e.printStackTrace();  
  43.         }  
  44.         return result;  
  45.     }  
  46. }  

源码下载:http://sdrv.ms/12ECmgG

P.S.

我也测试过Map固定数据类型value只为String的情况,这时Java与JSON的性能的差距会减小,但JSON序列化性能与数据大小还是占优势,尤其是反序列化的速度JSON更出色。

Gson在数值反序列化后,因为Object无法确定类型,Map中的Long,Integer,Float统一转为了Double类型。

json-smart不一样,如果整数超过Integer的范围转Long,没有超过转Integer。浮点Float转为Double类型。

原文链接:http://my.oschina.net/noahxiao/blog/112759

网站标题:Java序列化与JSON序列化大比拼
网站路径:http://www.mswzjz.cn/qtweb/news48/546248.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能