Android 使用Gson解析json不固定key(二)

2024-06-01 15:32

本文主要是介绍Android 使用Gson解析json不固定key(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

闲来无事分析一下Android在开发中,后台传来的数据需要回传给后台时,为什么需要明确key?

项目中使用的是Gson框架。
先来看看Person是怎么写的,常规写法,没毛病

public class Person implements Serializable {private String name;private Param param;public String getName() {return name;}public void setName(String name) {this.name = name;}public  class Param implements Serializable {private String id;public String getId() {return id;}public void setId(String id) {this.id = id;}}
}

再看一下请求,没异议

//界面数据-请求A接口
HttpRequestPresenter.getInstance().post(getActivity(), true, url_a, null, new IRequestCallBack() {@Overridepublic void success(String data, String msg) {//json{ "name":"fly","param": {"id":1}}Gson gson = new Gson();mPerson = gson.fromJson(data, Person.class);}@Overridepublic void failed(int errorCode, String msg, String data, String code) {}
});//把param中的数据回传-请求B接口
HashMap map = new HashMap();
map.put("id", String.valueOf(mPerson.param.id));
HttpRequestPresenter.getInstance().post(getActivity(), true, url_b, map, new IRequestCallBack() {@Overridepublic void success(String data, String msg) {}@Overridepublic void failed(int errorCode, String msg, String data, String code) {}
});

param在项目中协定为请求某接口所需参数,其中的内容参数无需知道,只需请求接口时,原封不动的再传给后台。

那么问题来了,如果在param中参数不固定的时候怎么办呢?
假如需求突然变了,请求B接口需要加一个参数comment,后台在A接口返回的param中新加了参数comment,此时此刻以上的代码就不对了。

这种情况为什么不能做成动态的呢?为什么不摒弃Gson的快捷应用,非得找后台加参数时要提前声明?

以下为我尝试解决这种情况的一种方法
前提我们已经协定了param是动态互传的,可以直接把param的类型改成HashMap。

public class Person implements Serializable {private String name;private HashMap<String, String> param;public String getName() {return name;}public void setName(String name) {this.name = name;}public void setParam(HashMap<String, String> param) {this.param = param;}public HashMap<String, String> getParam() {return param;}
}
//界面数据-请求A接口
HttpRequestPresenter.getInstance().post(getActivity(), true, url_a, null, new IRequestCallBack() {@Overridepublic void success(String data, String msg) {//json{ "name":"fly","param": {"id":1,"comment":"test"}}Gson gson = new Gson();mPerson = gson.fromJson(data, Person.class);}@Overridepublic void failed(int errorCode, String msg, String data, String code) {}
});//把param中的数据回传-请求B接口
HashMap map = mPerson.getParam();
HttpRequestPresenter.getInstance().post(getActivity(), true, url_b, map, new IRequestCallBack() {@Overridepublic void success(String data, String msg) {}@Overridepublic void failed(int errorCode, String msg, String data, String code) {}
});

就算其他地方需要使用param中的某个参数,也可以get到,不是非得使用对象点变量吧

HashMap map = mPerson.getParam();
String comment = map.get("comment").toString();

这么做有什么不好吗?

还遇到过一种情况
record中key是不固定的,value是固定结构。那我们可以把value的固定结构写出来,用的时候可以非常便捷。

{"name":"fly","param": {"id":1},"record":{"20190801":{"type":"a"},"20190802":{"type":"b"},"20190803":{"type":"c"}}
}
public class Person implements Serializable {private String name;private Param param;private HashMap<String, Record> record;public String getName() {return name;}public void setName(String name) {this.name = name;}public  class Param implements Serializable {private String id;public String getId() {return id;}public void setId(String id) {this.id = id;}}public  class Record implements Serializable {private String type;public String getType() {return type;}public void setType(String type) {this.type = type;}}
}
HttpRequestPresenter.getInstance().post(getActivity(), true, url_a, null, new IRequestCallBack() {@Overridepublic void success(String data, String msg) {Gson gson = new Gson();Person mPerson = gson.fromJson(data, Person.class);Map<String, Record> record = mPerson.getRecord();//一、遍历取出keyfor (String key:record.keySet()){Record value = record.get(key);String type = value.getType().toString();}//二、遍历取出键值对for (Map.Entry<String,Record> pair:record.entrySet()){String key = pair.getKey();Record value = pair.getValue();String type = value.getType().toString();} }@Overridepublic void failed(int errorCode, String msg, String data, String code) {}
});

另一种情况

{"data":{"1":"数字1","2":"数字2","3":"数字3"}
}
HttpRequestPresenter.getInstance().post(getActivity(), true, url_a, null, new IRequestCallBack() {@Overridepublic void success(String data, String msg) {Gson gson = new Gson();Map<String, Object> ps = gson.fromJson(data, new TypeToken<Map<String, Object>>(){}.getType());for (Map.Entry<String,Object> pair:ps.entrySet()){String key = pair.getKey();Record value = pair.getValue();String type = value.getType().toString();} }@Overridepublic void failed(int errorCode, String msg, String data, String code) {}
});

这篇关于Android 使用Gson解析json不固定key(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1021397

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用