我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android中JSON的4种解析方式使用和对比

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android中JSON的4种解析方式使用和对比

1 Android SDK自带的org.json解析

解析原理: 基于文档驱动,需要把全部文件读入到内存中,然后遍历所有数据,根据需要检索想要的数据。

相关类:

  • JSONObject
  • JSONArray
  • JSONTokener
public Object nextValue() throws JSONException {
    int c = nextCleanInternal();
    switch (c) {
        case -1:
            throw syntaxError("End of input");
            
        case '{':
            return readObject();
            
        case '[':
            return readArray();
            
        case ''':
        case '"':
            return nextString((char) c);
            
        default:
            pos--;
            return readLiteral();
    }
}
  • JSONStringer
  • JSONException

以下是Android SDK自带Json解析方式的示例代码:


public class OrgJsonUtil {
    
    public static void createJson(Context context) {
        try {
            File file = new File(context.getFilesDir(), "orgjson.json");
            //实例化一个JSONObject
            JSONObject student = new JSONObject();
            //向对象中添加数据
            student.put("name", "Musk");
            student.put("sex", "男");
            student.put("age", 50);

            JSONObject course1 = new JSONObject();
            course1.put("name", "数学");
            course1.put("score", 98.2f);
            JSONObject course2 = new JSONObject();
            course2.put("name", "语文");
            course2.put("score", 99);

            //实例化一个JSONArray
            JSONArray courses = new JSONArray();
            courses.put(0, course1);
            courses.put(1, course2);
            student.put("courses", courses);

            //写数据
            FileOutputStream fos = new FileOutputStream(file);
            fos.write(student.toString().getBytes());
            fos.close();
            Log.d("TAG", "createJson: " + student);

            Toast.makeText(context, "Json创建成功", Toast.LENGTH_SHORT).show();

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    
    public static void parseJson(Context context) {
        try {
            //读数据
            File file = new File(context.getFilesDir(), "orgjson.json");
            FileInputStream fis = new FileInputStream(file);
            InputStreamReader isr = new InputStreamReader(fis);
            BufferedReader br = new BufferedReader(isr);
            String line;
            StringBuffer sb = new StringBuffer();
            while (null != (line = br.readLine())) {
                sb.append(line);
            }
            fis.close();
            isr.close();
            br.close();

            Student student = new Student();
            JSONObject studentJsonObject = new JSONObject(sb.toString());

            //获取对象
            //使用optString在获取不到对应值的时候会返回空字符串"",而使用getString会异常
            String name = studentJsonObject.optString("name", "");
            String sex = studentJsonObject.optString("sex", "女");
            int age = studentJsonObject.optInt("age", 18);
            student.setName(name);
            student.setSex(sex);
            student.setAge(age);

            //获取数组
            List<Course> courses = new ArrayList<>();
            JSONArray coursesJsonArray = studentJsonObject.optJSONArray("courses");
            if (coursesJsonArray != null && coursesJsonArray.length() > 0) {
                for (int i = 0; i < coursesJsonArray.length(); i++) {
                    JSONObject courseJsonObject = coursesJsonArray.optJSONObject(i);
                    Course course = new Course();
                    String courseName = courseJsonObject.optString("name", "学科");
                    float score = (float) courseJsonObject.optDouble("score", 0);
                    course.setName(courseName);
                    course.setScore(score);
                    courses.add(course);
                }
            }
            student.setCourses(courses);

            Log.d("TAG", "parseJson: " + student);
            Toast.makeText(context, "Json解析成功", Toast.LENGTH_SHORT).show();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

2 Gson解析

解析原理: 基于事件驱动。

优势:

  • 快速,高效
  • 代码量少
  • 面向对象
  • 数据传输解析方便
  • 可按需解析

解析流程: 根据所需取的数据 建立1个对应于JSON数据的JavaBean类,即可通过简单操作解析出所需数据。
Gson 不要求JavaBean类里面的属性一定全部和JSON数据里的所有key相同,可以按需取数据。

使用:

  • JSON的大括号对应一个对象

    • 对象里面有key,value
    • JavaBean的类属性名 = key
  • JSON的中括号对应一个数组

  • JavaBean里面对应的也是数组

  • 对象里可以有值/对象

  • 若对象里面只有值,没有key,则说明是纯数组,对应JavaBean里的数组类型

  • 若对象里面有值和key,则说明是对象数组,对应JavaBean里的内部类

  • 对象嵌套

    • 建立内部类 该内部类对象的名字 = 父对象的key ,类似对象数组
{
    "key":"value",
    "simpleArray":[
        1,
        2,
        3
    ],
    "arrays":[
        {
            "arrInnerClsKey":"arrInnerClsValue",
            "arrInnerClsKeyNub":1
        }
    ],
    "innerclass":{
        "name":"Musk",
        "age":50,
        "sex":"男"
    }
}

与之对应的JavaBean:

public class JsonJavaBean {
    private String key;
    private List<Integer> simpleArray;
    private List<ArraysBean> arrays;
    private InnerclassBean innerclass;

    public String getKey() {
        return key;
    }

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

    public List<Integer> getSimpleArray() {
        return simpleArray;
    }

    public void setSimpleArray(List<Integer> simpleArray) {
        this.simpleArray = simpleArray;
    }

    public List<ArraysBean> getArrays() {
        return arrays;
    }

    public void setArrays(List<ArraysBean> arrays) {
        this.arrays = arrays;
    }

    public InnerclassBean getInnerclass() {
        return innerclass;
    }

    public void setInnerclass(InnerclassBean innerclass) {
        this.innerclass = innerclass;
    }

    private static class ArraysBean {
        private String arrInnerClsKey;
        private int arrInnerClsKeyNub;

        public String getArrInnerClsKey() {
            return arrInnerClsKey;
        }

        public void setArrInnerClsKey(String arrInnerClsKey) {
            this.arrInnerClsKey = arrInnerClsKey;
        }

        public int getArrInnerClsKeyNub() {
            return arrInnerClsKeyNub;
        }

        public void setArrInnerClsKeyNub(int arrInnerClsKeyNub) {
            this.arrInnerClsKeyNub = arrInnerClsKeyNub;
        }
    }

    private static class InnerclassBean {
        private String name;
        private int age;
        private String sex;

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }

        public String getSex() {
            return sex;
        }

        public void setSex(String sex) {
            this.sex = sex;
        }
    }
}

Gson解析示例代码:


public class GsonUse {

    public static void main(String[] args) throws Exception {
        Student student = new Student();
        student.setName("John");
        student.setAge(20);
        student.setSex("男");
        List<Course> courses = new ArrayList<>();
        courses.add(new Course("语文", 99));
        courses.add(new Course("地理", 59));
        student.setCourses(courses);

        Gson gson = new Gson();

        //在项目根目录下的json文件夹下生成Jgsonjson.json文件
        File file = new File("json/gsonjson.json");
        FileOutputStream fos = new FileOutputStream(file);
        OutputStreamWriter osw = new OutputStreamWriter(fos, "utf-8");
        JsonWriter jw = new JsonWriter(osw);
        gson.toJson(student, new TypeToken<Student>() {
        }.getType(), jw);
        jw.flush();
        jw.close();

        //反序列化为JavaBean
        FileInputStream fis = new FileInputStream(file);
        InputStreamReader isr = new InputStreamReader(fis);
        JsonReader jr = new JsonReader(isr);
        Student student1 = gson.fromJson(jr, new TypeToken<Student>() {
        }.getType());
        System.out.println(student1);
    }
}

3 Jackson解析

解析原理: 基于事件驱动。

优势: 解析效率最高;在数据量大的情况优势尤为明显、占存少。

缺点: Json数据里面的所有key都有所对应,也就是必须完全解析文档,如果要按需解析的话可以拆分Json来读取,操作和解析方法复杂。

适用场景: 适用于需要处理超大型JSON文档、不需要对JSON文档进行按需解析、性能要求较高的场合。

解析过程:

  • 类似Gson,先创建1个对应于JSON数据的JavaBean类,再通过简单操作即可解析。
  • 与Gson解析不同的是:Gson可按需解析,即创建的JavaBean类不一定完全涵盖所要解析的JSON数据,按需创建属性;但Jackson解析对应的JavaBean必须把Json数据里面的所有key都有所对应,即必须把JSON内的数据所有解析出来,无法按需解析。

使用:

引入依赖

//Jackson
implementation 'com.fasterxml.jackson.core:jackson-databind:2.13.1'
implementation 'com.fasterxml.jackson.core:jackson-core:2.13.1'
implementation 'com.fasterxml.jackson.core:jackson-annotations:2.13.1'


public class JacksonUse {
    public static void main(String[] args) throws Exception {
        Student student = new Student();
        student.setName("Lili");
        student.setSex("女");
        student.setAge(26);
        List<Course> courses = new ArrayList<>();
        courses.add(new Course("Art", 100));
        courses.add(new Course("Love", 99));
        student.setCourses(courses);

        ObjectMapper objectMapper = new ObjectMapper();
        //序列化 生成json文件
        File file = new File("json/jacksonjson.json");
        FileOutputStream fos = new FileOutputStream(file);
        objectMapper.writeValue(fos, student);

        //反序列化 json文件转为JavaBean
        Student student1 = objectMapper.readValue(file, Student.class);
        System.out.println(student1);
    }
}

注意:json里的key必须和JavaBean中的字段全部对应。

如果没对应,比如json中多了一个"hobby"字段,JavaBean中没有,运行就会报错:

Exception in thread "main" com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException: Unrecognized field "hobby" (class site.exciter.learn.json.Student), not marked as ignorable (4 known properties: "courses", "name", "sex", "age"])
 at [Source: (File); line: 3, column: 13] (through reference chain: site.exciter.learn.json.Student["hobby"])

4 Fastjson解析

特点:

  • 快速FAST(比任何一款都快)
  • 面向对象
  • 功能强大(支持普通JDK类任意java bean Class,Collection,Map,Date或者enum)
  • 零依赖(只需要有JDK即可)
  • 支持注解,全类型序列化

使用:

引入依赖

implementation 'com.alibaba:fastjson:1.2.76'

public class FastjsonUse {
    public static void main(String[] args) throws Exception {
        Student student = new Student();
        student.setName("Lili");
        student.setSex("女");
        student.setAge(26);
        List<Course> courses = new ArrayList<>();
        courses.add(new Course("Art", 100));
        courses.add(new Course("Love", 99));
        student.setCourses(courses);

        //序列化 生成json
        File file = new File("json/fastjson.json");
        FileOutputStream fos = new FileOutputStream(file);
        JSONObject.writeJSONString(fos, student);

        //反序列化 json转JavaBean
        FileInputStream fis = new FileInputStream(file);
        Student student1 = JSONObject.parseObject(fis, Student.class);
        System.out.println(student1);
    }
}

以上就是几种JSON解析方式的对比,目前来说还是Gson和FastJson用的相对来说比较多。更多相关Android JSON内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android中JSON的4种解析方式使用和对比

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android中使用Gson解析JSON数据的两种方法

Json是一种类似于XML的通用数据交换格式,具有比XML更高的传输效率. 从结构上看,所有的数据(data)最终都可以分解成三种类型: 第一种类型是标量(scalar),也就是一个单独的字符串(string)或数字(numbers),比如
2022-06-06

Android开发中synchronized的三种使用方式详解

这篇文章主要介绍了Android开发中synchronized的三种使用方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-05-16

Android应用中使用DOM方式解析XML格式数据的基本方法

DOM比SAX更容易掌握,因为她没有涉及回调和复杂的状态管理,然而,DOM的实现常常将所有的XML节点保存在内存中,这样使的处理较大的文档效率低。 XML基本的节点类型 node - DOM基本的数据类型 Element - 最主要处理的对
2022-06-06

Linux中使用curl命令访问https站点的4种常见错误和解决方法

这篇文章主要讲解了“Linux中使用curl命令访问https站点的4种常见错误和解决方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux中使用curl命令访问https站点的4种常
2023-06-13

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录