当前位置:首页 > 文章列表 > 文章 > java教程 > Gson解析空JSON列表的技巧

Gson解析空JSON列表的技巧

2025-09-26 22:45:37 0浏览 收藏

对于一个文章开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《Gson解析JSON空列表的正确方法》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

使用 Gson 解析 JSON 到 Java 对象时处理空列表

本文档旨在指导开发者在使用 Gson 库将 JSON 数据转换为 Java 对象时,如何正确处理 JSON 中可能出现的空列表情况,避免 MalformedJsonException 异常。通过调整 Java 类的结构和使用 Gson 的注解,可以有效地解决空列表带来的解析问题,确保数据转换的顺利进行。

Gson 是一个流行的 Java 库,用于在 Java 对象和 JSON 数据之间进行序列化和反序列化。在使用 Gson.fromJson() 方法时,如果 JSON 结构与 Java 类的定义不完全匹配,可能会遇到各种问题,例如 MalformedJsonException。本文将重点介绍如何处理 JSON 中列表为空的情况。

问题分析

当 JSON 数据中的列表(例如 product 列表中的 value 字段)为空时([]),Gson 仍然会尝试将该列表映射到 Java 类中对应的 List 属性。如果 Java 类中对列表元素的定义存在问题,例如期望列表中的元素具有某个特定的属性,但实际上列表为空,就会导致解析错误。

解决方案

解决此问题的关键在于确保 Java 类的定义能够正确地反映 JSON 数据的结构,并使用 Gson 的注解来指导解析过程。

1. 定义 Java 类

根据提供的 JSON 示例,我们定义以下 Java 类:

import com.google.gson.annotations.Expose;
import com.google.gson.annotations.SerializedName;

import java.util.List;

public class ProductDTO {

    @SerializedName("title")
    @Expose
    private String title;
    @SerializedName("product")
    @Expose
    private List<Product> product = null;

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public List<Product> getProduct() {
        return product;
    }

    public void setProduct(List<Product> product) {
        this.product = product;
    }

}
import com.google.gson.annotations.Expose;
import com.google.gson.annotations.SerializedName;

import java.util.List;

public class Product {

    @SerializedName("key")
    @Expose
    private String key;
    @SerializedName("value")
    @Expose
    private List<Value> value = null;

    public String getKey() {
        return key;
    }

    public void setKey(String key) {
        this.key = key;
    }

    public List<Value> getValue() {
        return value;
    }

    public void setValue(List<Value> value) {
        this.value = value;
    }

}
import com.google.gson.annotations.Expose;
import com.google.gson.annotations.SerializedName;

public class Value {

    @SerializedName("valueName")
    @Expose
    private String valueName;

    public String getValueName() {
        return valueName;
    }

    public void setValueName(String valueName) {
        this.valueName = valueName;
    }

}

2. 使用 Gson 注解

  • @SerializedName: 用于指定 JSON 字段的名称与 Java 类中属性的名称之间的映射关系。例如,@SerializedName("title") 表示将 JSON 中的 "title" 字段映射到 Java 类的 title 属性。
  • @Expose: 用于控制哪些属性应该被序列化和反序列化。如果一个属性没有使用 @Expose 注解,那么 Gson 默认会忽略该属性。

3. 解析 JSON 数据

import com.google.gson.Gson;

public class Main {
    public static void main(String[] args) {
        String jsonPayload = "{\n" +
                "  \"title\": \"title\",\n" +
                "  \"product\" : [\n" +
                "    {\n" +
                "      \"key\": \"product1\",\n" +
                "      \"value\": [{\n" +
                "        \"valueName\": \"productValue1\"\n" +
                "      }],\n" +
                "      \"date\" : \"2022-10-11\"\n" +
                "    },\n" +
                "    {\n" +
                "      \"key\": \"product2\",\n" +
                "      \"value\": []\n" +
                "    }\n" +
                "  ]\n" +
                "}";

        Gson gson = new Gson();
        ProductDTO productDTO = gson.fromJson(jsonPayload, ProductDTO.class);

        System.out.println("Title: " + productDTO.getTitle());
        if (productDTO.getProduct() != null) {
            for (Product product : productDTO.getProduct()) {
                System.out.println("Key: " + product.getKey());
                if (product.getValue() != null) {
                    for (Value value : product.getValue()) {
                        System.out.println("ValueName: " + value.getValueName());
                    }
                } else {
                    System.out.println("Value list is null");
                }

            }
        } else {
            System.out.println("Product list is null");
        }
    }
}

注意事项

  • 确保 Java 类的属性类型与 JSON 数据的类型匹配。
  • 使用 @SerializedName 注解来正确映射 JSON 字段和 Java 属性。
  • 使用 @Expose 注解来控制序列化和反序列化的行为。
  • 在处理列表时,要考虑列表为空的情况,并进行适当的判断和处理。

总结

通过正确定义 Java 类和使用 Gson 的注解,可以有效地解决在使用 Gson 解析 JSON 数据时遇到的空列表问题。确保 Java 类的结构能够准确地反映 JSON 数据的结构,并使用注解来指导解析过程,可以避免 MalformedJsonException 异常,并确保数据转换的顺利进行。

到这里,我们也就讲完了《Gson解析空JSON列表的技巧》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

ExcelHLOOKUP横向查找教程ExcelHLOOKUP横向查找教程
上一篇
ExcelHLOOKUP横向查找教程
GolangWeb会话与Cookie使用教程
下一篇
GolangWeb会话与Cookie使用教程
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 社媒分析AI:数说Social Research,用AI读懂社媒,驱动增长
    数说Social Research-社媒分析AI Agent
    数说Social Research是数说故事旗下社媒智能研究平台,依托AI Social Power,提供全域社媒数据采集、垂直大模型分析及行业场景化应用,助力品牌实现“数据-洞察-决策”全链路支持。
    29次使用
  • 先见AI:企业级商业智能平台,数据驱动科学决策
    先见AI
    先见AI,北京先智先行旗下企业级商业智能平台,依托先知大模型,构建全链路智能分析体系,助力政企客户实现数据驱动的科学决策。
    32次使用
  • 职优简历:AI驱动的免费在线简历制作平台,提升求职成功率
    职优简历
    职优简历是一款AI辅助的在线简历制作平台,聚焦求职场景,提供免费、易用、专业的简历制作服务。通过Markdown技术和AI功能,帮助求职者高效制作专业简历,提升求职竞争力。支持多格式导出,满足不同场景需求。
    28次使用
  • 一键证照:AI智能证件照在线制作,快速生成合格证件照
    一键证照
    告别传统影楼!一键证照,AI智能在线制作证件照,覆盖证件照、签证照等多种规格,免费美颜,快速生成符合标准的专业证件照,满足学生、职场人、出境人群的证件照需求。
    28次使用
  • 幂简AI提示词商城:专业AI提示词模板交易与效能优化平台
    幂简AI提示词商城
    幂简AI提示词商城是国内领先的专业级AI提示词模板交易平台,致力于降低优质提示词创作门槛,提升AI助手使用效率。提供3K+多领域专业提示词模板,支持变量替换、跨AI模型适配、API集成,解决提示词复用性低、效果不稳定、创作耗时等痛点。
    30次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码