Gson Builder — 序列化空值

作者: 無名小子的杂货铺 | 来源:发表于2016-12-05 16:34 被阅读1859次

原文链接:Gson Builder — Force Serialization of null Values
原文出自:Norman Peitek
译者:無名無

练习代码已上传 Github https://github.com/whiskeyfei/Gson-Review 可自行查看,每个例子都经过验证。

序列化空值

之前的文章也有相应的例子,比如空值的映射文中,如果你的数据结构中没有给字段赋值或者设置 null,序列化的 JSON 中是不会出现该字段的。

这种通过忽略null值设定的好处就是减少了 JSON 输出的大小。但是我们有时候并不想这样,有一些需求我们必须将所有的字段都要显示出来,不管是赋值没赋值,空还是不为空。

幸运的是 Gson 提供了设置的方法,我们将使用 GsonBuilder 来定制我们的规则。

public class UserSimple {  
    String name;
    String email;
boolean isDeveloper;
int age;
}

下面的例子和熟悉了,最基本的生成 JSON 方式:

Gson gson = new Gson();  
UserSimple user = new UserSimple("Norman", null, 26, true);  
String usersJson = gson.toJson(user);  

使用默认的规则,email 字段没有被输出:

{
      "age": 26,
      "isDeveloper": true,
      "name": "Norman"
}

如果你需要 email 被输出,只需要这么做,设置 GsonBuilder 的 serializeNulls 方法即可,如下 :

GsonBuilder gsonBuilder = new GsonBuilder();  
gsonBuilder.serializeNulls(); //重点
Gson gson = gsonBuilder.create();

UserSimple user = new UserSimple("Norman", null, 26, true);  
String usersJson = gson.toJson(user);

输出:

{
      "age": 26,
      "email": null,
       "isDeveloper": true,
      "name": "Norman"
}

目标

学习如何将空值在序列化时字段也被输出。
下一篇将介绍自定义的解析规则。

练习代码已上传 Github https://github.com/whiskeyfei/Gson-Review 可自行查看。

Gson 系列文章翻译回顾

1、Gson - Java-JSON 序列化和反序列化入门
2、Gson - 映射嵌套对象
3、Gson - Arrays 和 Lists 映射对象
4、Gson - Map 结构映射
5、Gson - Set 集合映射
6、Gson - 空值映射
7、Gson Model Annotations - 如何使用 @SerializedName 更改字段的命名
8、Gson Model Annotations - @SerializedName 匹配多个反序列化名称
9、Gson Builder - 基础和命名规则
10、Gson Builder - 序列化空值
11、Gson Builder - 忽略策略
12、Gson Builder - Gson Lenient 属性
13、Gson Builder - 特殊类型 Floats & Doubles
17、Gson Builder - 如何使用 @Expose 忽略字段
19、Gson Advanced - 映射枚举类型
20、Gson Advanced - 映射循环引用
21、Gson Advanced - 泛型
22、Gson Advanced - 简单自定义序列化 (Part 1)
24、Gson Advanced - 自定义反序列化基础
25、Gson Advanced - 自定义对象实例创建
26、Gson Advanced - 通过 @JsonAdapter 自定义(反)序列化过程
32、Practical Gson - 如何解析多态对象

学习讨论

刚刚建了一个 Android 开源库分享学习群,有兴趣的小伙伴可以加入一起学习。

群二维码

相关文章

网友评论

    本文标题:Gson Builder — 序列化空值

    本文链接:https://www.haomeiwen.com/subject/yunzpttx.html