91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MessagePack Jackson 數據大小

發布時間:2020-07-30 23:04:48 來源:網絡 閱讀:310 作者:HoneyMoose 欄目:大數據

我們在使用?MessagePack 對 List 對象數據進行序列化的時候,發現序列化以后的二進制數組數據偏大的情況。

請注意,不是所有的 List 對象都會出現這種情況,這個根據你 List 對象中存儲的內容有關。

有關本問題的測試源代碼請參考:https://github.com/cwiki-us-demo/serialize-deserialize-demo-java/blob/master/src/test/java/com/insight/demo/serialize/MessagePackDataTest.java?中的內容。

考察下面的代碼:

List<MessageData>?dataList?=?MockDataUtils.getMessageDataList(600000);
?
ObjectMapper?objectMapper?=?new?ObjectMapper(new?MessagePackFactory());
raw?=?objectMapper.writeValueAsBytes(dataList);
?
FileUtils.byteCountToDisplaySize(raw.length);
logger.debug("Raw?Size:?[{}]",?FileUtils.byteCountToDisplaySize(raw.length));

我們會發現,針對這個 60 萬個對象的 List 的序列化后的數據達到了 33MB。

如果我們再定義??ObjectMapper 對象的時候添加一部分參數,我們會發現大小將會有顯著改善。

請參考下面的代碼:

List<MessageData>?dataList?=?MockDataUtils.getMessageDataList(600000);
?
ObjectMapper?objectMapper?=?new?ObjectMapper(new?MessagePackFactory());
objectMapper.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES,?true);
objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES,?false);
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
objectMapper.setAnnotationIntrospector(new?JsonArrayFormat());
?
rawJsonArray?=?objectMapper.writeValueAsBytes(dataList);
logger.debug("rawJsonArray?Size:?[{}]",?FileUtils.byteCountToDisplaySize(rawJsonArray.length));

如果你運行上面的代碼,你會看到程序的輸出字符串將會降低到 23MB。

這里面主要是?objectMapper.setAnnotationIntrospector(new JsonArrayFormat());?這句話起了作用。

在正常的場景中,我們可以通過 注解 JsonIgnore, 將其加到屬性上,即解析時即會過濾到屬性。

而實際實現,則是由類?JacksonAnnotationIntrospector?中 的?hasIgnoreMarker?來完成,則就是通過讀取注解來判斷屬性是否應該被exclude掉。ObjectMapper中默認的?AnnotationIntrospector?即是?JacksonAnnotationIntrospector?來完成,但我們可以通過 方法?ObjectMapper.setAnnotationIntrospector?來重新指定自定義的實現。

?

https://www.cwiki.us/display/Serialization/MessagePack+Jackson+Data+Size


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

华池县| 张北县| 六安市| 纳雍县| 景洪市| 双牌县| 厦门市| 都昌县| 苏尼特右旗| 西宁市| 漳浦县| 唐海县| 江陵县| 肃宁县| 上蔡县| 定结县| 扶余县| 新闻| 林州市| 奎屯市| 亳州市| 临武县| 紫阳县| 达日县| 东乌| 博客| 灌阳县| 文昌市| 六安市| 丰城市| 广昌县| 积石山| 托克托县| 溧水县| 玉门市| 福贡县| 芜湖市| 灌云县| 巫山县| 唐山市| 新安县|