在發展中Android的過程當中。假設咱們常與server聯繫,更新數據等,而後,json它必須是一個良好的數據格公式,但隨着json。使用原生的解析也可以,但是很是不高效,因此這裏介紹兩種json數據解析的方式,一種是FastJSon ,這個是阿里巴巴出的,號稱最快的解析速度。另一種使咱們偉大的Google提供的Gson 來解析json,兩個解析json都很是方便,而且都很是強大,在我使用中,基本上都知足了個人需求,如下簡單就接受一下,咱們的用法。html
首先創建兩個實體類。Student.java 和 Teacher.java java
Student.java 和Teacher.java 的代碼例如如下:android
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來寫,避免一些位置的錯誤。json
上面主要主要的介紹完了。就開始解析。首先要下載fastjson 和Gson的jar包,這個網上很是多請自行下載。ide
首先看 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格式。this
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 列表的這個也在咱們常常使用的數據模型,如下看看代碼: spa
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);
結果爲:code
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 keyword,來標記它爲不需要的,在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倍。
很久沒有寫博客了,文採通常,但但願你們能夠喜歡,多提意見,一塊兒進步。什麼每一個人都想知道,你也能夠留言,慢慢學習在我身後。而後評論。