前言
最近在做系統Bug修復時遇到了一個問題,調用其他服務時傳遞的參數和自己預先的不一致,例如Map中有10條記錄,然后使用JSON.toJSONString 包裝后進行網絡傳遞,但是通過調試發現接收方只收到了5條數據。經過追溯發現原來JSON.toJSONString 這里有坑。所以現在總結記錄一下。
FastJson簡介
首先,介紹一下fastjson。fastjson是由alibaba開源的一套json處理器。與其他json處理器(如Gson,Jackson等)和其他的Java對象序列化反序列化方式相比,有比較明顯的性能優勢。詳情可以參考fastjson提供的benchmark。
https://github.com/eishay/jvm-serializers/wiki
采坑實例
上面已經說到我遇到問題的描述了,下面直接看代碼實例:
這里箭頭指向的位置,因為sent-1 中的value為空,所以並未打印出來。
第二個使用:JSON.toJSONString(map, SerializerFeature.WriteMapNullValue) 指定序列化方式就打印出來了。
所以大家使用的時候一定切記這里的坑。下面再看看fastJson一些默認一下屬性:
JSON.toJSONString 源碼:
然后看下SerializerFeature屬性:
名稱 | 含義 |
QuoteFieldNames | 輸出key時是否使用雙引號,默認為true |
UseSingleQuotes | 使用單引號而不是雙引號,默認為false |
WriteMapNullValue | 是否輸出值為null的字段,默認為false |
WriteEnumUsingToString | Enum輸出name()或者original,默認為false |
SortField | 按字段名稱排序后輸出。默認為false |
WriteTabAsSpecial | 把\t做轉義輸出,默認為false |
PrettyForma | 結果是否格式化,默認為false |
WriteClassName | 序列化時寫入類型信息,默認為false。反序列化是需用到 |
...... | ...... |
看到這里大家可以針對自己的需求選擇不同序列化格式,更多SerializerFeature 請大家自行查閱。