Android fastJson和Gson

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ZM_Crazy/article/details/50014489

在开发Android的过程中,如果我们经常与服务器打交道,更新数据等等,那么json必然是个好的数据格式,但是有了json我们要解析它,使用原生的解析也可以,但是很不高效,所以这里介绍两种json数据解析的方式,一种是FastJSon ,这个是阿里巴巴出的,号称最快的解析速度。第二种使我们伟大的Google提供的Gson 来解析json,两个解析json都很方便,而且都很强大,在我使用中,基本上都满足了我的需求,下面简单就接受一下,我们的使用方法。


JSON的定义

1.JSON和XML的数据可读性基本相同
2.JSON和XML同样拥有丰富的解析手段
3.JSON相对于XML来讲,数据的体积小
4.JSON与JavaScript的交互更加方便
5.JSON对数据的描述性比XML较差
 
6.JSON的速度要远远快于XML

android2.3提供的json解析类 


JSONObject:可以看作是一个json对象,这是系统中有关JSON定义的基本单元,其包含一对儿(Key/Value)数值。它对外部(External:   应用toString()方法输出的数值)调用的响应体现为一个标准的字符串(例如:{"JSON": "Hello, World"},最外被大括号包裹,其中的Key和Value被冒号":"分隔)。其对于内部(Internal)行为的操作格式略微,例如:初始化一个JSONObject实例,引用内部的put()方法添加数值:new JSONObject().put("JSON", "Hello, World!"),在Key和Value之间是以逗号","分隔。Value的类型包括:Boolean、JSONArray、JSONObject、Number、String或者默认值JSONObject.NULL object 。


JSONStringer:json文本构建类 ,根据官方的解释,这个类可以帮助快速和便捷的创建JSON text。其最大的优点在于可以减少由于 格式的错误导致程序异常,引用这个类可以自动严格按照JSON语法规则(syntax rules)创建JSON text。每个JSONStringer实体只能对应创建一个JSON text。。其最大的优点在于可以减少由于格式的错误导致程序异常,引用这个类可以自动严格按照JSON语法规则(syntax rules)创建JSON text。每个JSONStringer实体只能对应创建一个JSON text。


JSONArray:它代表一组有序的数值。将其转换为String输出(toString)所表现的形式是用方括号包裹,数值以逗号”,”分隔(例如:     [value1,value2,value3],大家可以亲自利用简短的代码更加直观的了解其格式)。这个类的内部同样具有查询行为,     get()和opt()两种方法都可以通过index索引返回指定的数值,put()方法用来添加或者替换数值。同样这个类的value类型可以包括:Boolean、JSONArray、JSONObject、Number、String或者默认值JSONObject.NULL object。



JSONTokener:json解析类 
JSONException:json中用到的异常 

键值对转换成json数值

        // 假设现在要创建这样一个json文本
        // {
        // "phone" : ["12345678", "87654321"], // 数组
        // "name" : "crazyzm", // 字符串
        // "age" : 100, // 数值
        // "address" : { "country" : "china", "province" : "jiangsu" }, // 对象
        // "married" : false // 布尔值
        // }

        try {
            // 首先最外层是{},是创建一个对象
            JSONObject person = new JSONObject();
            // 第一个键phone的值是数组,所以需要创建数组对象
            JSONArray phone = new JSONArray();
            phone.put("12345678").put("87654321");
            person.put("phone", phone);

            person.put("name", "crazyzm");
            person.put("age", 100);
            // 键address的值是对象,所以又要创建一个对象
            JSONObject address = new JSONObject();
            address.put("country", "china");
            address.put("province", "llsf");
            person.put("address", address);
            person.put("married", false);
            return  person.toString();
        } catch (JSONException ex) {
            // 键为null或使用json不支持的数字格式(NaN, infinities)
            throw new RuntimeException(ex);
        }

getType和optType api的使用   
getType可以将要获取的键的值转换为指定的类型,如果无法转换或没有值则抛出JSONException 
optType也是将要获取的键的值转换为指定的类型,无法转换或没有值时返回用户提供或这默认提供的值 

try {  
    // 所有使用的对象都是用上面创建的对象  
    // 将第一个电话号码转换为数值和将名字转换为数值  
    phone.getLong(0);  
    person.getLong("name"); // 会抛异常,因为名字无法转换为long        
    phone.optLong(0); // 代码内置的默认值  
    phone.optLong(0, 1000); // 用户提供的默认值  
    person.optLong("name");  
    person.optLong("name", 1000); // 不像上面那样抛异常,而是返回1000  
} catch (JSONException ex) {  
    // 异常处理代码  
}  

  1 public static final Object parse(String text); // 把JSON文本parse为JSONObject或者JSONArray  
  2 public static final JSONObject parseObject(String text); // 把JSON文本parse成JSONObject     
  3 public static final  T parseObject(String text, Class clazz); // 把JSON文本parse为JavaBean  
  4 public static final JSONArray parseArray(String text); // 把JSON文本parse成JSONArray  
  5 public static final  List parseArray(String text, Class clazz); //把JSON文本parse成JavaBean集合  
  6 public static final String toJSONString(Object object); // 将JavaBean序列化为JSON文本  
  7 public static final String toJSONString(Object object, boolean prettyFormat); // 将JavaBean序列化为带格式的JSON文本  
  8 public static final Object toJSON(Object javaObject); 将JavaBean转换为JSONObject或者JSONArray。

例子

猜你喜欢

转载自blog.csdn.net/ZM_Crazy/article/details/50014489