日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java中 byte[]数组序列化和fastjson序列化区别

發布時間:2024/9/30 java 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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實現方法比較簡單。

下面對性能進行了對比:

類別1000次5000次10000次100000次1000000次
byte數組82ms147ms213ms827ms5707ms
fastJson114ms157ms146ms174ms412ms

此數據來自i7 16g內存windows eclipse軟件測試得來。

可以看出來在大規模數據的情況下fastJson還是非常快的。

總結

以上是生活随笔為你收集整理的Java中 byte[]数组序列化和fastjson序列化区别的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。