android java json_Android实战中与Json数据、Java-Bean相关的效率技巧

本文已授权公众号「伯特说」原创首发。

在实际开发中,难免会与网络数据打交道,这就涉及到 Json 数据字段分析、解析,转换成 Java Bean 等相关内容。那么本文就围绕这几个点,为大家介绍几个技巧、插件,提升开发效率。

下面开始正文。

1. 准备数据

首先,我们需要有数据,以我在聚合数据上申请的菜谱大全为例[只有免费的1000次,用完就没了,请惜之],接口地址如下:

如果你发现上面的接口失效了,我备份了一份,访问 并手动复制即可。

其实,你完全可以自己申请一个 key 来测试,把上面接口的 key 换成你申请的就可以了。

2.直观的查看数据

类似于上面的接口,在开发中,后台同事给了接口,我们肯定要先看一眼,确认下是什么样的数据格式。那怎么看呢?把上面的接口粘贴到浏览器的地址栏,回车:

d13de213f5cc

直接查看 Json 数据.png

卧槽,这乱七八糟的怎么看?

d13de213f5cc

你在逗我.png

想必你和我一样,第一反应是崩溃的。别着急,自有办法。

使用 Chrome 浏览器的同学,可以借助 Json-handle 插件方面的查看 Json 数据:对JSON格式的内容进行浏览和编辑,以树形图样式展现JSON文档,并可实时编辑。

这是我用过的最好用的 Json 展示和编辑插件,如果有更好的,欢迎推荐。在 Chrome 商店中的地址如下:

装好插件后,再次刷新刚才的 api 地址,神奇的一幕发生了:

d13de213f5cc

使用 Json-handle 查看.png

是不是很清晰?展开、收起,想怎么看就怎么看。许多对 Json 数据结构不了解的童鞋,可以借这个插件学习分析 Json 结构,很直观。

同时,其还具备其它同类插件没有的功能,直接将光标放在图片 URL 上,可以直接预览图片,GIF 也可以:

d13de213f5cc

Json-handle 预览图片.png

更多功能等你去探索,我们接着往后。

3.生成 Json 对应的 Java Bean

预览返回的 Json 数据后,你可能已经迫不及待想要解析数据了。且慢,在此之前,我们还差一步:生成 Java Bean,也就是我们常说的实体对象,这样才能将返回的 Json 数据转化成内存中的对象使用。

一说到这,我们立马头大了,再次预览上面的数据:

d13de213f5cc

再次预览结构.png

我们的核心是 result 对象,其包含了一个 data 数组,对应着10个菜谱对象;每个菜谱对象又包含若干属性,有简单的类似 id,title的字段,但也有 albums,steps这样的复杂数组...

这样的数据结构,其复杂程度应该不亚于实际开发中大多数场景了。但是,这岂能难倒我们?

要知道这是我精心挑选出来做示例的 API,没有难度怎么有说服力。下面一起来秒杀它!

d13de213f5cc

秒杀.jpg

根据上面的分析,假设我们关心 result 所包含的数据,那么我们的 Bean 实体的数据结构最后大致是这样的:

//result

public class CookRequestResult {

//result 包含的 data 数组,即若干菜谱

private List data;

//data 中每个菜谱对象

public static class DataBean {

//菜谱的 steps,即做菜时的若干步骤

private List steps;

//每个步骤对象

public static class StepsBean {

}

}

}

上述抛开了基本类型字段,简化后概括来说:

CookRequestResult 包含 DataBean 对象集合,DataBean 中又包含 StepsBean 对象集合。分别对应上面的 api 返回的 result,data 和 steps。

这样一个数据结构,手写起来,不仅麻烦,还容易出错,如何是好?这就轮到本文的第二个插件 GsonFormat 登场了。

d13de213f5cc

登场.gif

下面简单说下从安装到使用的过程:

首先,在 Android Studio 的插件中,搜索 GsonFormat,安装并重启生效:

d13de213f5cc

安装 GsonFormat.png

然后,新建一个空的实体类,命名 CookRequestResult,表示菜谱请求返回的数据;

接下来,在 Json-handle 中选中 result 节点,复制右侧窗口的数据:

d13de213f5cc

在 Json-handle中复制result.png

最后,打开新建的类,按快捷键 Alt + Insert,调出 Generate 窗口,选择刚才安装的 GsonFormat,粘贴数据。点击 OK 并确认所有字段后,插件就会根据 Json 生成 CookRequestResult 的字段(非基本类型的字段,会生成对应的内部静态类),并生成对字段对应的 getter 和 setter 方法。

最后效果如下(粘贴代码时为避免冗余,去除了 getter 和 setter 方法):

/**

* 菜谱请求数据

* Created by ruicbAndroid on 2017/7/23.

*/

public class CookRequestResult {

private String totalNum;

private String pn;

private String rn;

private List data;

public static class DataBean {

private String id;

private String title;

private String tags;

private String imtro;

private String ingredients;

private String burden;

private List albums;

private List steps;

public static class StepsBean {

private String img;

private String step;

}

}

}

很给力有木有。可以看出,GsonFormat 支持以内部静态类的形式一层层嵌套对象,强大到超乎你想象(当然了,你也可以手动将内部类对象提出去)。

以上就是关于生成 Java Bean 的介绍,你应该自己试一试,我说再多都不如自己动手来的直接、形象。

4.解析 Json 数据

历经千辛万苦(有点夸张了,如果熟练的话,上面的操作也就几分钟的事),终于可以解析 Json 数据了。但是这一块不是本文的重点,就一带而过。

一般就是通过网络请求数据,获取数据,然后将数据映射为对应的 Bean。解析 Json 数据常用方式有二:

使用 Gson 或者 FastJson 等解析库,具体用法就不展开了。

使用 SDK 中自带的 JsonObject,JsonArray 等自行解析数据,这样可以避免引入三方库。

具体使用哪种方式看自己需求了,这块没有技巧可言,靠的是扎实的技术基础。

5.序列化对象

至此,我们已经可以从容的应对 Json 的分析、生成 Java Bean 和解析 Json

数据,还差最后一步:序列化 Java Bean。

在开发中,我们难免需要在组件之间传递数据,比如从列表页点击进入详情,此时通过 Intent 传递数据时就需要序列化对象。序列化对象的方式,一般有两种:

实现 Serializable 接口;

实现 Parcelable,并重写对应方法;

实现 Serializable 较为简单,直接添加 implements 即可;

而实现 Parcelable 接口,则需要重写相应的方法,指定你需要序列化及反序列化的字段,还是比较麻烦的。以上面的 DataBean 为例,实现 Parcelable 接口后会新增以下内容:

public static class DataBean implements Parcelable {

//省略已经贴过的代码...

//以下是实现 Parcelable 接口需要新增的代码

@Override

public int describeContents() {

return 0;

}

@Override

public void writeToParcel(Parcel dest, int flags) {

dest.writeString(this.id);

dest.writeString(this.title);

dest.writeString(this.tags);

dest.writeString(this.imtro);

dest.writeString(this.ingredients);

dest.writeString(this.burden);

dest.writeStringList(this.albums);

dest.writeList(this.steps);

}

public DataBean() {

}

protected DataBean(Parcel in) {

this.id = in.readString();

this.title = in.readString();

this.tags = in.readString();

this.imtro = in.readString();

this.ingredients = in.readString();

this.burden = in.readString();

this.albums = in.createStringArrayList();

this.steps = new ArrayList();

in.readList(this.steps, StepsBean.class.getClassLoader());

}

public static final Parcelable.Creator CREATOR = new Parcelable.Creator() {

@Override

public DataBean createFromParcel(Parcel source) {

return new DataBean(source);

}

@Override

public DataBean[] newArray(int size) {

return new DataBean[size];

}

};

}

这还没完,因为 DataBean 包含了 StepsBean,其不属于基本数据类型,我们还需要让 StepsBean 实现 Parcelable 接口并重写相应的方法...

d13de213f5cc

我不听.gif

两个方案,至于选哪个,看你自己。二者各有优势:

Serializable:简单,实现个接口即可,但序列化、反序列化效率相对较低;

Parcelable:序列化、反序列化效率更高,但实现起来复杂;

一想到 Parcelable 实现起来的复杂程度,我们懒癌又犯了,忍不住说服自己实现 Serializable,毕竟现在手机性能都不差,不差那点~~

但是,有些人懒癌比我们还严重,他们既考虑到性能问题,又希望自动生成实现 Parcelable 接口时需要写的代码。于是乎,对应的插件应运而生,一劳永逸。

d13de213f5cc

我很欣赏你.jpg

在 Android Studio 搜索 Parcelable 关键字,安装 Android Parcelable code generator 插件并重启让插件生效;

回到 CookRequestResult 类,将光标定到 DataBean 内部类中;

使用快捷键 Alt + Insert 调出 Generate 窗口,选择 Parcelable,确认需要序列化的字段后点击 OK,搞定!

序列化的效果就是上面贴出的代码,就不重复贴了。

最后,让 StepsBean 也实现 Parcelable,异曲同工了啊。

收工,关电脑出去浪,不负好时光~

6.总结

至此,本文告一段落了。由于篇幅有限,许多细节没有展开讲,不过事无巨细,我把工具、思路抛出来,各位可以自行查阅、实践。实践过程中,有任何问题都可以留言提出。

就酱,周末愉快~ 有帮助就顺手关注我的公众号~

d13de213f5cc

伯特说

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值