当我们使用Gson解析json数据时都会创建一个对应实体类,有时候json数据里面的字段是java关键词或者json数据里面的字段太简单,我们想在实体类中自定义字段名,这时就可以用@SerializedName注解,将我们自定义的字段名与json数据里面的字段对应起来。
如有用java关键字定义的Gson对象json1和用简单字段定义的Gson对象json2,具体定义代码如下:
//json1
{
"public":"1",
"class":"2",
"static":"3"
}
//json2
{
"a":"1",
"b":"2",
"c":"3"
}
json1 中数据如果建立一个相同字段名的实体类显然是不可行的,因为json1里面的几个key如public、class、static都是java语言中的关键字,这个时候@SerializedName注解就起到了作用。使用@SerializedName注解定义的Gson对象ResponseBean1如下:
public class ResponseBean1{
@SerializedName("pulic")
private String pub;
@SerializedName("class")
private String cla;
@SerializedName("static")
private String sta;
}
json2 中的数据用的是比较简单的字段,如a、b、c,如果直接建立对应字段名的实体类理解起来很不友好,这个时候可以通过使用@SerializedName注解来自定义字段名。使用@SerializedName注解定义的Gson对ResponseBean2如下:
public class Json2{
@SerializedName("a")
private String pub; // 对象名可以自定义
@SerializedName("b")
private String cla; // 对象名可以自定义
@SerializedName("c")
private String sta; // 对象名可以自定义
}
总结:1、使用@SerializedName注解,可以将自定义的字段名与json数据里面的字段对应起来;2、需要gson序列化的model(一般定义为Bean类),一般不会混淆,因为混淆后,会导致Bean类里面的属性名字发生改变,然后gson反序列化就会找不到对应的属性名;也可以混淆,然后使用@serializedName来注释,这样当混淆后,反序列化通过注释来找到对应的字段。所以得出的推荐写法是,用@serializedName来注释Bean对象类,这样即使把Bean对象类混淆了,也不会影响gson对象的反序列化。
如果感觉我的文章对您有用,请给个喜欢,如果有疑问,也欢迎在下方留言,谢谢!!!
网友评论