Gson序列化的一些点

本文探讨了Gson在Java对象与JSON数据之间的转换策略,包括如何使用@JsonIgnoreProperties忽略未知或指定字段,FieldNamingPolicy的不同策略如LOWER_CASE_WITH_UNDERSCORES对字段名的影响,以及如何通过@SerializedName自定义字段映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.忽略不存在的字段、忽略指定字段:

@JsonIgnoreProperties(ignoreUnknown = true),将这个注解写在类上之后,就会忽略类中不存在的字段。

@JsonIgnoreProperties({ "data", "hasMore" })
指定的字段不会被序列化和反序列化。
 

2.FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES 之后转换的规则就有变化了,转换的规则就变成来源的名称必须是 小写 和 _ 的组合,才能匹配待对应的 JOPO的属性中,比如

"{\"name_you\":\"gson\"}"可以转换成 nameYou 或者 name_you的json串,但是

"{\"nameYou\":\"gson\"}"    转换 nameYou 或者 name_you 都失败。

 

3.FieldNamingPolicy是在序列化和反序列化的时候,根据策略进行解析,比如LOWER_CASE_WITH_UNDERSCORES是将下层返回的name_you转换成nameYou,将输出的nameYou转换成name_you;

 

4.FieldNamingPolicy包括以下几种:

 a)IDENTITY,完全匹配我们 Java model 中的字段名,不管你有没有设置其他注解属性;

 b)LOWER_CASE_WITH_UNDERSCORES ,将修改生成的 JSON 中的字段名,将全部变成小写,并且每个单词用“_” 分割;

 c)LOWER_CASE_WITH_DASHES,将修改生成的 JSON 中的字段名,将全部变成小写,并且每个单词用“-” 分割;

 d)UPPER_CAMEL_CASE,将每个单词的第一个字母都要大写,其他不变;

 e)UPPER_CAMEL_CASE_WITH_SPACES,每个单词的第一个字母会大写,每个单词使用空格分隔;

还可以自定义规格来处理

 

5.对于上述的规则,不满足的,要不然自定义规则,要不然使用注解

  @SerializedName("resultDesc")来匹配;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值