当前位置: 首页 > news >正文

Jackson注解实战:@JsonInclude的妙用

在日常的Java开发中,我们经常需要将Java对象序列化为JSON格式,以便进行数据传输或存储。然而,有时候我们并不希望在JSON中包含某些空值或不必要的字段,这不仅会增加数据的冗余性,还可能对后续的处理造成困扰。Jackson库中的@JsonInclude注解为我们提供了一种优雅的解决方案。今天,我们就来深入探讨一下@JsonInclude(JsonInclude.Include.NON_EMPTY)的使用方法和实际效果。

一、@JsonInclude的背景与作用

@JsonInclude注解是Jackson库提供的一个强大工具,用于控制对象序列化时字段的包含规则。其中,JsonInclude.Include.NON_EMPTY选项可以排除那些被认为是“空”的值。具体来说,以下几种情况会被视为“空”:

  • Null值:字段值为null
  • 空字符串:字段值为""
  • 空集合或数组:例如ListMap、数组等,其长度或isEmpty()方法返回true

通过使用@JsonInclude(JsonInclude.Include.NON_EMPTY),我们可以轻松地过滤掉这些空值,使生成的JSON更加简洁和清晰。

二、实例解析

为了更好地理解@JsonInclude(JsonInclude.Include.NON_EMPTY)的作用,我们来看一个具体的例子。

1. 定义Java对象

首先,我们定义一个Employee类,该类包含了一些常见的字段,如姓名、部门、地址、电话号码列表和薪资等。

package com.logicbig.example;import com.fasterxml.jackson.annotation.JsonInclude;
import java.math.BigDecimal;
import java.util.List;
import java.util.concurrent.atomic.AtomicReference;@JsonInclude(JsonInclude.Include.NON_EMPTY)
public class Employee {private String name;private String dept;private String address;private List<String> phones;private AtomicReference<BigDecimal> salary;// Getter和Setter方法省略
}

Employee类上,我们添加了@JsonInclude(JsonInclude.Include.NON_EMPTY)注解,这表示在序列化时,所有空值字段都将被排除。

2. 主程序代码

接下来,我们编写一个主程序来测试Employee类的序列化效果。

import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.IOException;
import java.util.ArrayList;public class ExampleMain {public static void main(String[] args) throws IOException {Employee employee = new Employee();employee.setName("Trish");employee.setDept("");employee.setAddress(null);employee.setPhones(new ArrayList<>());employee.setSalary(new AtomicReference<>());ObjectMapper om = new ObjectMapper();String jsonString = om.writeValueAsString(employee);System.out.println(jsonString);}
}

在主程序中,我们创建了一个Employee对象,并为其设置了部分字段。其中,dept字段为空字符串,address字段为nullphones字段是一个空的ArrayListsalary字段是一个未初始化的AtomicReference

3. 运行结果

运行上述代码后,输出结果如下:

{"name":"Trish"}

可以看到,只有name字段被序列化到JSON中,其他空值字段(如deptaddressphonessalary)都被成功排除。

三、对比其他注解选项

为了更直观地理解@JsonInclude(JsonInclude.Include.NON_EMPTY)的效果,我们可以对比其他几种注解选项。

1. 不使用@JsonInclude注解

如果我们在Employee类中不使用@JsonInclude注解,那么序列化结果将是:

{"name":"Trish","dept":"","address":null,"phones":[],"salary":null}

可以看到,所有字段都被序列化到JSON中,包括空字符串、null值、空集合和未初始化的AtomicReference

2. 使用@JsonInclude(JsonInclude.Include.NON_NULL)

如果我们将@JsonInclude注解的值改为JsonInclude.Include.NON_NULL,那么序列化结果将是:

{"name":"Trish","dept":"","phones":[],"salary":null}

在这种情况下,只有null值字段被排除,空字符串和空集合仍然会被序列化。

3. 使用@JsonInclude(JsonInclude.Include.NON_ABSENT)

如果我们将@JsonInclude注解的值改为JsonInclude.Include.NON_ABSENT,那么序列化结果将是:

{"name":"Trish","dept":"","phones":[]}

在这种情况下,null值字段和未初始化的AtomicReference字段被排除,但空字符串和空集合仍然会被序列化。

四、总结

通过上述实例和对比,我们可以清楚地看到@JsonInclude(JsonInclude.Include.NON_EMPTY)的强大功能。它能够帮助我们过滤掉所有“空”值字段,从而生成更加简洁、高效的JSON数据。在实际开发中,合理使用@JsonInclude注解可以大大提升数据序列化的质量,减少不必要的数据传输和存储开销。

此外,Jackson库还提供了丰富的注解和功能,值得我们深入学习和探索。希望本文能够帮助你更好地理解和应用@JsonInclude注解,提升你的开发效率和代码质量。

http://www.lryc.cn/news/545670.html

相关文章:

  • CAN总线通信协议学习1——物理层
  • Vim 常用快捷键大全:跳转、编辑、查找替换全解析
  • 【Python 数据结构 2.时间复杂度和空间复杂度】
  • 【Qt QML】QML鼠标事件(MouseArea)
  • LeetCode 202. 快乐数 java题解
  • 《认知·策略·跃迁:新能源汽车工程师的深度学习系统构建指南》
  • PHP环境安装达梦数据库驱动实操
  • Electron + Vite + React + TypeScript 跨平台开发实践指南
  • Java---入门基础篇(下)---方法与数组
  • 【分布式理论11】分布式协同之分布式事务(一个应用操作多个资源):从刚性事务到柔性事务的演进
  • 【文献阅读】Collective Decision for Open Set Recognition
  • Gorm中的First()、Create()、Update()、Delete()的错误处理
  • 【心得】一文梳理高频面试题 HTTP 1.0/HTTP 1.1/HTTP 2.0/HTTP 3.0的区别并附加记忆方法
  • Navicat连接虚拟机数据库详细教程
  • 委托者模式(掌握设计模式的核心之一)
  • DeepSeek-R1 论文笔记:通过强化学习提升大语言模型的推理能力
  • 实现Unity shader扭曲效果
  • 七星棋牌 6 端 200 子游戏全开源修复版源码(乐豆 + 防沉迷 + 比赛场 + 控制)
  • C++STL---<limits>
  • 一键安装Mysql部署脚本之Linux在线安装Mysql,脚本化自动化执行服务器部署(附执行脚本下载)
  • ES、OAS、ERP、电子政务、企业信息化(高软35)
  • 文生图开源模型发展史(2014-2025年)
  • OA办公系统自动渗透测试过程
  • Python标准库【os】5 文件和目录操作2
  • [代码规范]接口设计规范
  • 什么是最终一致性,它对后端系统的意义是什么
  • Unity学习笔记之——ugui的性能优化
  • Python接口自动化中操作Excel文件的技术方法
  • [Windows] 免费电脑控制手机软件 极限投屏_正式版_3.0.1 (QtScrcpy作者开发)
  • 游戏引擎学习第131天