Android中JSON的理解與實例
JSON的定義:
一種輕量級的數(shù)據(jù)交換格式,具有良好的可讀和 便于快速編寫的特性。業(yè)內(nèi)主流技術(shù)為其提供了完整的解決方案(有點類似于正則表達式 ,獲得了當今大部分語言的支持),從而可以在不同平臺間進行數(shù)據(jù)交 換。JSON采用兼容性很高的文本格式,同時也具備類似于C語言體系的行為。 – Json.org
JSON Vs XML
1.JSON和XML的數(shù)據(jù)可讀性基本相同
2.JSON和XML同樣擁有豐富的解析手段
3.JSON相對于XML來講,數(shù)據(jù)的體積小
4.JSON與JavaScript的交互更加方便
5.JSON對數(shù)據(jù)的描述性比XML較差
6.JSON的速度要遠遠快于XML
android2.3提供的json解析類
android的json解析部分都在包org.json下,主要有以下幾個類:
JSONObject:可以看作是一個json對象,這是系統(tǒng)中有關(guān)JSON定義的基本單元,其包含一對兒(Key/Value)數(shù)值。它對外部(External: 應用toString()方法輸出的數(shù)值)調(diào)用的響應體現(xiàn)為一個標準的字符串(例如:{"JSON": "Hello, World"},最外被大括號包裹,其中的Key和Value被冒號":"分隔)。其對于內(nèi)部(Internal)行為的操作格式略微,例如:初始化一個JSONObject實例,引用內(nèi)部的put()方法添加數(shù)值:new JSONObject().put("JSON", "Hello, World!"),在Key和Value之間是以逗號","分隔。Value的類型包括:Boolean、JSONArray、JSONObject、Number、String或者默認值JSONObject.NULL object 。
JSONStringer:json文本構(gòu)建類 ,根據(jù)官方的解釋,這個類可以幫助快速和便捷的創(chuàng)建JSON text。其最大的優(yōu)點在于可以減少由于 格式的錯誤導致程序異常,引用這個類可以自動嚴格按照JSON語法規(guī)則(syntax rules)創(chuàng)建JSON text。每個JSONStringer實體只能對應創(chuàng)建一個JSON text。。其最大的優(yōu)點在于可以減少由于格式的錯誤導致程序異常,引用這個類可以自動嚴格按照JSON語法規(guī)則(syntax rules)創(chuàng)建JSON text。每個JSONStringer實體只能對應創(chuàng)建一個JSON text。
JSONArray:它 代表一組有序的數(shù)值。將其轉(zhuǎn)換為String輸出(toString)所表現(xiàn)的形式是用方括號包裹,數(shù)值以逗號”,”分隔(例如: [value1,value2,value3],大家可以親自利用簡短的代碼更加直觀的了解其格式)。這個類的內(nèi)部同樣具有查詢行為, get()和opt()兩種方法都可以通過index索引返回指定的數(shù)值,put()方法用來添加或者替換數(shù)值。同樣這個類的value類型可以包括:Boolean、JSONArray、JSONObject、Number、String或者默認值JSONObject.NULL object。
JSONTokener:json解析類
JSONException:json中用到的異常
JSONObject, JSONArray來構(gòu)建json文本
- // 假設(shè)現(xiàn)在要創(chuàng)建這樣一個json文本
- // {
- // "phone" : ["12345678", "87654321"], // 數(shù)組
- // "name" : "yuanzhifei89", // 字符串
- // "age" : 100, // 數(shù)值
- // "address" : { "country" : "china", "province" : "jiangsu" }, // 對象
- // "married" : false // 布爾值
- // }
- try {
- // 首先最外層是{},是創(chuàng)建一個對象
- JSONObject person = new JSONObject();
- // 第一個鍵phone的值是數(shù)組,所以需要創(chuàng)建數(shù)組對象
- JSONArray phone = new JSONArray();
- phone.put("12345678").put("87654321");
- person.put("phone", phone);
- person.put("name", "yuanzhifei89");
- person.put("age", 100);
- // 鍵address的值是對象,所以又要創(chuàng)建一個對象
- JSONObject address = new JSONObject();
- address.put("country", "china");
- address.put("province", "jiangsu");
- person.put("address", address);
- person.put("married", false);
- } catch (JSONException ex) {
- // 鍵為null或使用json不支持的數(shù)字格式(NaN, infinities)
- throw new RuntimeException(ex);
- }
getType和optType api的使用
getType可以將要獲取的鍵的值轉(zhuǎn)換為指定的類型,如果無法轉(zhuǎn)換或沒有值則拋出JSONException
optType也是將要獲取的鍵的值轉(zhuǎn)換為指定的類型,無法轉(zhuǎn)換或沒有值時返回用戶提供或這默認提供的值
- try {
- // 所有使用的對象都是用上面創(chuàng)建的對象
- // 將第一個電話號碼轉(zhuǎn)換為數(shù)值和將名字轉(zhuǎn)換為數(shù)值
- phone.getLong(0);
- person.getLong("name"); // 會拋異常,因為名字無法轉(zhuǎn)換為long
- phone.optLong(0); // 代碼內(nèi)置的默認值
- phone.optLong(0, 1000); // 用戶提供的默認值
- person.optLong("name");
- person.optLong("name", 1000); // 不像上面那樣拋異常,而是返回1000
- } catch (JSONException ex) {
- // 異常處理代碼
- }
除了上面的兩個類,還可以使用JSONStringer來構(gòu)建json文本
- try {
- JSONStringer jsonText = new JSONStringer();
- // 首先是{,對象開始。object和endObject必須配對使用
- jsonText.object();
- jsonText.key("phone");
- // 鍵phone的值是數(shù)組。array和endArray必須配對使用
- jsonText.array();
- jsonText.value("12345678").value("87654321");
- jsonText.endArray();
- jsonText.key("name");
- jsonText.value("yuanzhifei89");
- jsonText.key("age");
- jsonText.value(100);
- jsonText.key("address");
- // 鍵address的值是對象
- jsonText.object();
- jsonText.key("country");
- jsonText.value("china");
- jsonText.key("province");
- jsonText.value("jiangsu");
- jsonText.endObject();
- jsonText.key("married");
- jsonText.value(false);
- // },對象結(jié)束
- jsonText.endObject();
- } catch (JSONException ex) {
- throw new RuntimeException(ex);
- }