1.资料
官网: http://groups.google.com/group/google-gson
代码: https://github.com/google/gson
jar包下载: http://search.maven.org/#artifactdetails%7Ccom.google.code.gson%7Cgson%7C2.3.1%7Cjar
2.导入
在as工程属性中找最新的gson库,或者直接在module的build.gradle中引入gson库.
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support.constraint:constraint-layout:1.1.2'
//...
implementation 'com.google.code.gson:gson:2.8.5'
}
3 json反列化
3.1准备对象
public class Person { private String name;
private int age; /**
* @return the name
*/
public String getName() {
return name;
} /**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
} /**
* @return the age
*/
public int getAge() {
return age;
} /**
* @param age the age to set
*/
public void setAge(int age) {
this.age = age;
} @Override
public String toString()
{
return name + ":" +age;
}
}
实体很简单,两个字段,当然实体中的字段也可以是List或者Set类型的。
3.2 生成Json字符串
//生成Json字符串 Gson gson = new Gson();
List<Person> persons = new ArrayList<Person>();
for (int i = ; i < ; i++) {
Person p = new Person();
p.setName("name" + i);
p.setAge(i * );
persons.add(p);
}
String json = gson.toJson(persons);
上面的代码重点是Gson对象,它提供了toJson()方法将对象转换成Json字符串,可以这个json串写到文件中.上面代码的str对象值为:
[{"name":"name0","age":0},{"name":"name1","age":5},{"name":"name2","age":10},{"name":"name3","age":15},
{"name":"name4","age":20},{"name":"name5","age":25},{"name":"name6","age":30},{"name":"name7","age":35},
{"name":"name8","age":40},{"name":"name9","age":45}]
3.3 gson把对象转成json的系列函数
- String toJson(Object src, Type typeOfSrc)
- String toJson(Object src)
- JsonElement toJsonTree(Object src, Type typeOfSrc)
- JsonElement toJsonTree(Object src)
4.反序列化
Gson提供了fromJson()方法来实现从Json相关对象到java实体的方法。
在日常应用中,通常转成单一实体对象和转换成对象列表或者其他结构。
4.1反序列化一个对象
当返回的是简单对象(只一个对象)时用gson.fromJson(string,xx.class); //提供两个参数,分别是json字符串以及需要转换对象的类型
比如json字符串为:
[{"name":"name0","age":0}]
代码:
Person person = gson.fromJson(str, Person.class);
4.2 反序列成列表
当返回的是复杂对象,要用AVA泛型时,如有个集合(0-n)要用gson.fromJson(string,new TypeToken<XXX>(){}.getType());
代码:
List<Person> ps = gson.fromJson(str, new TypeToken<List<Person>>(){}.getType());
for(int i = ; i < ps.size() ; i++)
{
Person p = ps.get(i);
System.out.println(p.toString());
}
上面的代码使用了TypeToken,它是gson提供的数据类型转换器,可以支持各种数据集合类型转换。
5. Gson处理 null
默认情况下,gson不处理null,处理方法如下:
5.1 定义 null 处理类
class StringConverter : JsonSerializer<String?>,
JsonDeserializer<String?> {
override fun serialize(
src: String?, typeOfSrc: Type?,
context: JsonSerializationContext?
): JsonElement {
return if (src == null) {
JsonPrimitive("")
} else {
JsonPrimitive(src.toString())
}
} @Throws(JsonParseException::class)
override fun deserialize(
json: JsonElement, typeOfT: Type?,
context: JsonDeserializationContext?
): String {
return json.asJsonPrimitive.asString
}
}
5.2 修改构造gson方式
fun parseDevices(array : JsonArray){
val gb = GsonBuilder()
gb.registerTypeAdapter(String::class.java, StringConverter())
val gson = gb.create()
for (je in array){
val obj = je.asJsonObject
if(!obj.has("type")) continue
val type = obj.get("type").asInt
when(type){
-> {
val ward = gson.fromJson(je,Wardship::class.java)
...
} //...
}
}
}