其实本来android前端定义的对象类型是对象,如果后台没有值的情况下,理论上给null,如果是数组给[]或者null都可以的。这样Gson再解析转换的时候就不会出问题!但是最近重构发现后台如果没有字段值给的是""空字符串,有值给的是对象字符串,比如下面:
"\"test\":" +
"{" +
"\"name\": \"hl\", " +
"\"id\": \"110\"" +
"}," +
这样我的Gson解析就报了字段类型不匹配的相关错误!最好的解决方式,其实是后台字段规范统一,而且尽量不要给脏数据,否则时间长很难维护和优化!
另外一种情况就是前端做特殊处理,用Object去接收,用Object去接收的话,使用的时候就相对麻烦,你需要自己做转换!
比如你的test字段定义的是Object test; 那么Gson解析的时候得到的结果类型是
class com.google.gson.internal.LinkedTreeMap
也就是一个hashmap的一种类型,这个时候就不是你说的对象了。那怎么办?一种情况是,你判断下如果是这种类型的话,如下操作:
先把linkedTreeMap对象转成json字符串,然后再转成JavaBean
Gson gson = new Gsonbuilder.enableComplexMapKeySerialization().create();
String jsonString = gson.toJson(linkedTreeMap);
JavaBean bean = gson.fromJson(jsonString,JavaBean.class);
另一种方式就是JavaBean提供一个构造函数,允许传入LinkedTreeMap进行构造,相当于自己取值来给对象变量赋值!貌似第一种方式更好。采用第一种,你可以判断是LinkedTreeMap还是String类型,然后统一做处理!相当于就统一封装到了请求数据解析环节.....
附上自己的一些练习学习吧:
import com.google.gson.Gson;
import com.google.gson.internal.LinkedTreeMap;
import java.util.Map;
import java.util.Set;
public class TEstSVDF {
private class User {
private Object test;
private String aa;
private String age;
public Object getTest() {
return test;
}
public void setTest(Object test) {
this.test = test;
}
public String getAa() {
return aa;
}
public void setAa(String aa) {
this.aa = aa;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
private class Test {
private String id;
private String name;
}
}
public static void main(String[] args) {
Object a = 1;
Object b = 10;
System.out.println("托尔斯泰" + (a.toString() + b));
String jsonStr = "{" +
"\"test\":" +
"{" +
"\"name\": \"hl\", " +
"\"id\": \"110\"" +
"}," +
" \"aa\":\"啊\", " +
"\"age\": \"10000\"" +
"}";
String jsonStr2 = "{" +
"\"test\":\"sb\", " +
"\"aa\":\"啊\", " +
"\"age\": \"10000\"" +
"}";
Gson gson = new Gson();
User user = gson.fromJson(jsonStr, User.class);
User user2 = gson.fromJson(jsonStr2, User.class);
System.out.println(user.getAa());
System.out.println(user.getAge());
System.out.println(user.getTest().getClass());
if (user.getTest() instanceof LinkedTreeMap) {
// 遍历
Set set = ((LinkedTreeMap) user.getTest()).entrySet();
for (Object o : set) {
Map.Entry entry = (Map.Entry) o;
System.out.print(entry.getKey() + ":" + entry.getValue() + " ");
}
// 对应取值
LinkedTreeMap linkedTreeMap = (LinkedTreeMap) user.getTest();
System.out.print(linkedTreeMap.get("id"));
System.out.print(linkedTreeMap.get("name"));
} else if (user.getTest() instanceof User.Test) {
User.Test test = (User.Test) user.getTest();
System.out.println("id=" + test.id);
System.out.println("name=" + test.name);
}
if (user2.getTest() instanceof String) {
System.out.println(user2.getTest());
}
}
}
Gson支持泛型哟。。。那样的话,或许对你自己封装rx家族,自定义处理请求和数据有很大帮助。小萌新的之前封装的目前来用还是不错。。但是今天又接触了一些Gson的东西后,还可以再完善下.....当然还得多向好的第三方库学习.....
这个链接还是满全面的 Java 中 Gson的使用 - 【cosmo】 - 博客园