Java中 byte[]数组序列化和fastjson序列化区别
生活随笔
收集整理的這篇文章主要介紹了
Java中 byte[]数组序列化和fastjson序列化区别
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Java中 byte[]數組序列化和fastjson序列化區別
Java中,對于對象可以通過序列化成byte數組或者序列化成json形式,這里做下兩者的對比。
首先看下實現方式:
1 byte數組序列化
這里由兩個方法,一個是對象序列化為字節數組,一個是字節數組序列化為對象,這里需要注意的是對象的serialVersionUID 必須設置為一樣才能序列化,否則哪怕兩個類長得一模一樣都會報錯。
private static byte[] ObjectToByte(Object obj) {byte[] bytes = null;try {// object to bytearrayByteArrayOutputStream bo = new ByteArrayOutputStream();ObjectOutputStream oo = new ObjectOutputStream(bo);oo.writeObject(obj);bytes = bo.toByteArray();bo.close();oo.close();} catch (Exception e) {System.out.println("translation" + e.getMessage());e.printStackTrace();}return bytes; }/*** byte轉對象* @param bytes* @return*/ private static Object ByteToObject(byte[] bytes) {Object obj = null;try {// bytearray to objectByteArrayInputStream bi = new ByteArrayInputStream(bytes);ObjectInputStream oi = new ObjectInputStream(bi);obj = oi.readObject();bi.close();oi.close();} catch (Exception e) {System.out.println("translation" + e.getMessage());e.printStackTrace();}return obj; }2 fastjson序列化
這里選擇了fastJson來序列化對象,實現方式如下:
public static <T> T get(String data, Class<T> clazz) {T body = JSON.parseObject(data, clazz);return body; }public static String toJson(Object o) {return JSONObject.toJSONString(o); }fastJson實現方法比較簡單。
下面對性能進行了對比:
| byte數組 | 82ms | 147ms | 213ms | 827ms | 5707ms |
| fastJson | 114ms | 157ms | 146ms | 174ms | 412ms |
此數據來自i7 16g內存windows eclipse軟件測試得來。
可以看出來在大規模數據的情況下fastJson還是非常快的。
總結
以上是生活随笔為你收集整理的Java中 byte[]数组序列化和fastjson序列化区别的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring运行期间配置文件解析返回
- 下一篇: Java中重写equals()方法时注意