Java目標和Json之間的互轉,尋常用的比力多的兩個類庫是Jackson和Gson,底下紀錄一下Gson的學習使用。
基本看法:
Serialization:序列化,使Java目標到Json字符串的歷程。
Deserialization:反序列化,字符串轉換成Java目標
Gson的兩個基本辦法
toJson();
fromJson();
Gson的創建辦法一:直接new Gson目標
// 使用new辦法
Gson gson = new Gson();
// toJson 將bean目標轉換為json字符串
String jsonStr = gson.toJson(user, User.class);
// fromJson 將json字符串轉為bean目標
Student user= gson.fromJson(jsonStr, User.class);
// **序列化List**
String jsonStr2 = gson.toJson(list);
// **反序列化成List時必要使用到TypeToken getType()**
List<User> retList = gson.fromJson(jsonStr2,new TypeToken<List<User>>(){}.getType());
Gson的創建辦法二:使用GsonBuilder
使用new Gson(),此時會創建一個帶有默許設置選項的Gson實例,假如不想使用默許設置,那么就可以使用GsonBuilder。
//serializeNulls()是GsonBuilder提供的一種設置,當字段值為空或null時,仍然對該字段舉行轉換
Gson gson = new GsonBuilder().serializeNulls().create();
使用GsonBuilder創建Gson實例的步調:
起首創建GsonBuilder,然后調用GsonBuilder提供的種種設置辦法舉行設置,
最初調用GsonBuilder的create辦法,將基于如今的設置創建一個Gson實例。
GsonBuilder的一些設置
Gson gson = new GsonBuilder()
.excludeFieldsWithoutExposeAnnotation() //不合錯誤沒有效@Expose注解的屬性舉行利用
.enableComplexMapKeySerialization() //當Map的key為繁復目標時,必要開啟該辦法
.serializeNulls() //當字段值為空或null時,仍然對該字段舉行轉換
.setDateFormat("yyyy-MM-dd HH:mm:ss:SSS") //時間轉化為特定格式
.setPrettyPrinting() //對后果舉行格式化,增長換行
.disableHtmlEscaping() //避免特別字符顯現亂碼
.registerTypeAdapter(User.class,new UserAdapter()) //為某特定目標設置安穩的序列或反序列辦法,自界說Adapter需完成JsonSerializer大概JsonDeserializer接口
.create();
Gosn對繁復Map的處理時必要用到此中的
enableComplexMapKeySerialization() 設置:
Gson gson = new GsonBuilder()
.enableComplexMapKeySerialization().create(); //開啟繁復處理Map辦法
Map<List<User>, String> map = new HashMap<List<User>, String>();
// TODO 向map中添加數據
String jsonStr = gson.toJson(map); //toJson
Map<List<User>, String> resultMap = gson.fromJson(jsonStr,new TypeToken<Map<List<User>, String>>() {}.getType()); //fromJson
注意:假如Map的key為String,則可以不使用GsonBuilder的
enableComplexMapKeySerialization()辦法,大概直接new Gson();
版權聲明:本文來自互聯網整理發布,如有侵權,聯系刪除
原文鏈接:http://www.freetextsend.comhttp://www.freetextsend.com/shenghuojineng/53245.html