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


转载请注明出处:( http://blog.csdn.net/My_TrueLove/article/details/75903130)

访问 ruicb.com,一键抵达我的博客!

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

下面开始正文。

1. 准备数据

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

点击访问 api 接口

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

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

申请地址:https://www.juhe.cn/docs/api/id/46

2.直观的查看数据

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

这里写图片描述

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

这里写图片描述

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

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

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

https://chrome.google.com/webstore/detail/json-handle/iahnhfdhidomcpggpaimmmahffihkfnj?hl=zh-CN

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

这里写图片描述

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

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

这里写图片描述

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

3.生成 Json 对应的 Java Bean

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

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

这里写图片描述

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

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

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

这里写图片描述

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

//result
public class CookRequestResult {

    //result 包含的 data 数组,即若干菜谱
    private List<DataBean> data;

    //data 中每个菜谱对象
    public static class DataBean {

        //菜谱的 steps,即做菜时的若干步骤
        private List<StepsBean> steps;

        //每个步骤对象
        public static class StepsBean {

        }
    }
}

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

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

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

这里写图片描述

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

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

    这里写图片描述

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

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

    这里写图片描述

  • 最后,打开新建的类,按快捷键 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<DataBean> 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<String> albums;
        private List<StepsBean> 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<StepsBean>();
        in.readList(this.steps, StepsBean.class.getClassLoader());
    }
    public static final Parcelable.Creator<DataBean> CREATOR = new Parcelable.Creator<DataBean>() {
        @Override
        public DataBean createFromParcel(Parcel source) {
            return new DataBean(source);
        }
        @Override
        public DataBean[] newArray(int size) {
            return new DataBean[size];
        }
    };
}

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

这里写图片描述

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

  • Serializable:简单,实现个接口即可,但序列化、反序列化效率相对较低;
  • Parcelable:序列化、反序列化效率更高,但实现起来复杂;

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

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

这里写图片描述

让我们看看怎么使用插件吧。

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

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

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

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

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

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

6.总结

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


扫描下方二维码,关注我的公众号《伯特说》,及时获取最新文章推送!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值