FastJSON是一个Java语言编写的高性能,功能完善,完全支持http://json.org的标准的JSON库。
在开发Android的过程中,如果我们经常与服务器打交道,更新数据等等,那么json必然是个好的数据格式,但是有了json我们要解析它,使用原生的解析也可以,但是很不高效,所以这里介绍两种json数据解析的方式,
一种是FastJSon ,这个是阿里巴巴出的,号称最快的解析速度。
第二种使我们伟大的Google提供的Gson 来解析json,两个解析json都很方便,而且都很强大,在我使用中,基本上都满足了我的需求,下面简单就接受一下,我们的使用方法。
首先建立两个实体类,Student.java 和 Teacher.java
Student.java 和Teacher.java 的代码如下:
package com.android.fastjson.bean; public class Student { private int id; private String name; private int age; /** * 默认的构造方法必须不能省,不然不能解析 */ public Student(){ } public Student(int id,String name,int age) { this.id = id; this.name = name; this.age = age; } public int getId() { return id; } public void setId(int id) { this.id = id; } 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; } @Override public String toString() { return "Student [id=" + id + ", name=" + name + ", age=" + age + "]"; } }
package com.android.fastjson.bean; import java.util.List; public class Teacher { private int id; private String name; private List<Student> students; /** * 默认的构造方法必须不能省,不然不能解析 */ public Teacher() { } public Teacher(int id,String name) { this.id = id; this.name = name; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public List<Student> getStudents() { return students; } public void setStudents(List<Student> students) { this.students = students; } @Override public String toString() { return "Teacher [id=" + id + ", name=" + name + ", mStudents=" + students + "]"; } }
上面 的代码比较简单,主要就几个属性,这里值得注意的是, 默认的构造函数一定要写,不然是无法解析的。(对于fastjson 严格按照JavaBean的规范来,有一点不对就无法解析,这里一定要切记,每一个实体类的属性的get , set 方法必须写,切方法第四个字母必须大写,最好使用Eclipse的source->genreal setters and getters 生成get,set 方法,切记,切记 )。对于Gson 这里就没有这么多的要求了,但最好还是按照JavaBean来写,避免一些位置的错误。
上面主要基本的介绍完了,就开始解析,首先要下载fastjson 和Gson的jar包,这个网上很多请自行下载。
首先看 fastjson 的解析
首先解析一个实体类为json 格式。
Student student = new Student(0, "Aaron", 24); System.out.println(JSON.toJSONString(student));
输出结果为:{"age":24,"id":0,"name":"Aaron"}
输出的json格式与我们的Student中定义的属性其实是不一致的,这个其实不影响我们生成以及后面的解析,因为他有严格的get和set方法定义。
更复杂一点的数据类型也可以很方便的使用JSON.toJsonString(Object o) 这个方法进行解析成json格式。
List<Student> students = new ArrayList<Student>(); for(int i=0;i<5;i++) { Student stu = new Student(i, "Student" + i, 18 +i); students.add(stu); }
解析结果为:
[{"age":18,"id":0,"name":"Student0"},{"age":19,"id":1,"name":"Student1"},{"age":20,"id":2,"name":"Student2"},{"age":21,"id":3,"name":"Student3"},{"age":22,"id":4,"name":"Student4"}]
我们来看看更复杂一点的结构。 我们将一个Teacher 列表来解析,一个Teacher对象中是包含Student 列表的这个也在我们常用的数据模型,下面看看代码:
List<Teacher> teaList = new ArrayList<Teacher>(); long time = System.currentTimeMillis(); for(int i=0;i<10;i++) { Teacher teacher = new Teacher(i, "Teacher " + i); List<Student> stus = new ArrayList<Student>(); for(int j = 0 ;j<4;j++) { Student s = new Student(j, "Student" + j, 18 +j); stus.add(s); } teacher.setStudents(stus); teaList.add(teacher); } String jsonTeach = JSON.toJSONString(teaList); System.out.println("fastjson = " + jsonTeach);
结果为:
fastjson = [{"id":0,"name":"Teacher 0","students":[{"age":18,"id":0,"name":"Student0"},{"age":19,"id":1,"name":"Student1"}]},{"id":1,"name":"Teacher 1","students":[{"age":18,"id":0,"name":"Student0"},{"age":19,"id":1,"name":"Student1"}]},{"id":2,"name":"Teacher 2","students":[{"age":18,"id":0,"name":"Student0"},{"age":19,"id":1,"name":"Student1"}]},{"id":3,"name":"Teacher 3","students":[{"age":18,"id":0,"name":"Student0"},{"age":19,"id":1,"name":"Student1"}]}]
还是一个简单的函数而已,就能办到。
这个还有toJSONString 重载的方法,有很多,在给一个就是可以按照标准的json 格式输出,上面的输出都不规范,我们来看看,
Student student = new Student(0, "Aaron", 24); System.out.println(JSON.toJSONString(student,true));
输出为:
{ "age":24, "id":0, "name":"Aaron" }
如果我们想要将实体类中的某个字段或某几个不进行解析呢?那么我们可以使用transient 关键字,来标记它为不需要的,在fastjson中还提供了一种便捷的方法来自定义我们需要序列化的字段,
SimplePropertyPreFilter filter = new SimplePropertyPreFilter(实体类.class, "字段1","字段2"); 字段为我们需要序列化的字段,如果实体类中没有改字段则不解析放弃该字段而不会报错。
如下:
SimplePropertyPreFilter filter = new SimplePropertyPreFilter(Student.class, "id","age"); String jsonStu =JSON.toJSONString(students,filter);
这样就只会序列化 id和age 的字段。
下面进行fastjson 的反序列化,这个也是很常用的功能,
还是拿最简单的来进行示范,
Student student = new Student(0, "Aaron", 24); String str = JSON.toJSONString(student,true); System.out.println(JSON.parseObject(str,Student.class));
反序列化主要使用的是JSON.parseObject(str,class); 它就能把我们的str 转化为class 类型的对象,当然还有更复杂的对象,比如:
List<Student> students = new ArrayList<Student>(); for(int i=0;i<5;i++) { Student stu = new Student(i, "Student" + i, 18 +i); students.add(stu); } // 过滤哪些属性需要转换 // SimplePropertyPreFilter filter = new SimplePropertyPreFilter(Student.class, "id","age"); // String jsonStu =JSON.toJSONString(students,filter); String jsonStu =JSON.toJSONString(students); System.out.println(jsonStu); List<Student> stu =JSON.parseObject(jsonStu, new TypeReference<List<Student>>(){}); for(int i=0;i<stu.size();i++) { System.out.println(stu.get(i)); }
前面就是添加数据,然后在后面解析为json格式,然后在转化为类的对象,这里转为List<Student> 对象,主要用到new TypeReference<数据返回类型> (){},我们使用的就是new TypeReference<List<Student>>(){} 返回的结果就是List<Student>
也不需要强制转化,我们看看上面输出的结果为:
Student [id=0, name=Student0, age=18] Student [id=1, name=Student1, age=19] Student [id=2, name=Student2, age=20] Student [id=3, name=Student3, age=21] Student [id=4, name=Student4, age=22]
当然fastjson 能处理的数据类型还有很多很多,我主要列了我常用的数据类型,今天主要就讲到这里。
后面我会将也简单介绍下Gson 的基本使用,然后在和fastjson进行对比,看看时间是否真的比gson 快6倍。
好久没有写博客了,文采一般,但希望大家能够喜欢,多提意见,一起进步。大家有什么想要了解的也可以留言,我后面慢慢的进行学习,然后进行讲解。
总结
以上所述是小编给大家介绍的Java 中FastJson的基本使用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍Java的JSON处理器fastjson使用方法详解,包括了Java的JSON处理器fastjson使用方法详解的使用技巧和注意事项,需要的朋友参考一下 fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。 主要特点: • 快速FAST (比其它任何基于Java的解析器和生成器更快,包括jackson) • 强大(支持普通JD
fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。 主要特点: 快速FAST (比其它任何基于Java的解析器和生成器更快,包括jackson) 强大(支持普通JDK类包括任意Java Bean Class、Collection、Map、Date或enum) 零依赖(没有依赖其它任何类库除了JDK) 示例代码: import com.al
我有一个基本的maven项目,其文件夹结构为:-main和-test目录。 我在主源目录中有一个包,它由几个类组成,比如a.class,B.class和c.class,它们都在同一个包下。所有类之间都有依赖关系。为了进行适当的单元测试,并减少每个类的依赖关系,我编写了每个a、b和c类的存根类,将它们定义为具有相同的包,并将它们放在测试源目录中。然后我运行:mvn测试 很好,现在首先从类路径中找到并
一、Sqoop 基本命令 1. 查看所有命令 # sqoop help 2. 查看某条命令的具体使用方法 # sqoop help 命令名 二、Sqoop 与 MySQL 1. 查询MySQL所有数据库 通常用于 Sqoop 与 MySQL 连通测试: sqoop list-databases \ --connect jdbc:mysql://hadoop001:3306/ \ --usern
一、Selenium的Java编程基本语法 在Selenium的基本语法中首先是需要定位到页面元素的,Selenium通过找寻到界面元素然后触发相应的时间,通过页面元素变化判断是否执行了相应的操作。 可以通过页面元素的属性获取相应的页面元素。 1.通过Identifier(id)定位元素 所给出的定位的HTML元素必须要有identifier,如果没有就会报告未找到相应元素的错
一个SQLite使用的简单例子。实现联系人信息的Demo,使用SQLite进行存取,并可以查询。 [Code4App.com]