官方文档地址:http://google-gson.googlecode.com/svn/trunk/gson/docs/javadocs/index.html

官方网站:http://code.google.com/p/google-gson/

json官方网站:http://www.json.org/json-zh.html

目前主流数据传输都用的是json,解析json并且转换成相应的类型就成了必经之路。

在没有使用gson之前,原生Andoird自带有类解析json,但是实在不方便使用。

先介绍一下Android原生的解析

在Android中包含四个与JSON相关的类和一个Exceptions:
JSONArray
JSONObject
JSONStringer
JSONTokener
JSONException

(1)JSONObject:
这是系统中有关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。
有两个不同的取值方法:
get(): 在确定数值存在的条件下使用,否则当无法检索到相关Key时,将会抛出一个Exception信息。
opt(): 这个方法相对比较灵活,当无法获取所指定数值时,将会返回一个默认数值,并不会抛出异常。

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

使用起来是这样的

  1. //将此json数据变成一个对象。
  2. JSONObject jsonObject = new JSONObject(String);
  3. //然后获得list里面的数据
  4. JSONArray jsonArray = jsonObject.getJSONArray("list");
  5.  
  6. //当不知道key时,使用循环
  7. for(int i=;i<jsonArray.length();i++)
  8. {
  9. JSONObject jsonOb = (JSONObject)jsonArray.opt(i);
  10. int tel = jsonOb.getInt("tel");
  11. }

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

  1. String myString = new JSONStringer().object().key("name").value("小猪").endObject().toString();
  2. //结果是一组标准格式的JSON text:{"name" : "小猪"}

其中的.object()和.endObject()必须同时使用,是为了按照Object标准给数值添加边界。同样,针对数组也有一组标准的方法来生成边界.array()和.endArray()。

(4)JSONTokener:
这个是系统为JSONObject和JSONArray构造器解析JSON source string的类,它可以从source string中提取数值信息。
(5)JSONException:
是JSON.org类抛出的异常信息。

自从使用了gson,一切都变得简单了

Gson有两个重要的方法,一个是toJson,一个是fromJson,也就是序列化和反序列化。

使用起来非常简单

  1. Gson gson = new Gson();
  2. //序列化
  3. MyObject myobj = new MyObject();
  4. String jsonstr = gson .toJson(myobj);
  5.  
  6. //反序列化
  7. MyObject myobj = gson.fromJson(jsonstr, MyObject.class);
  8.  
  9. //序列化数组
  10. String[] days = {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
  11. String numbersJson = gson.toJson(numbers);
  12.  
  13. //序列化集合
  14. List<String> myobjs = new ArrayList<String>();
  15. String jsonstr = gson.toJson(myobjs);
  16.  
  17. //反序列化集合数组
  18. List<MyObject> myobjs = gson.fromJson(str, new TypeToken<ArrayList<MyObject>>(){}.getType());

同时Gson还支持使用注解,在com.google.gson.annotation包中,有几个注解Expose, SerializedName, Since和Until,他们各有各的作用,下面使用官方例子介绍常用的注解:

Expose

  此注解作用在属性上,表明当序列化和反序列化的时候,这个属性将会暴露给Gson对象。这个注解只有当创建Gson对象时使用GsonBuilder方式创建并调用了GsonBuilder.excludeFieldsWithoutExposeAnnotation() 方法的时候才有效,否则无效。下面是一个介绍@Expose注解如何使用的例子:

  1. public class User {
  2.  @Expose private String firstName;
  3.  @Expose(serialize = false) private String lastName;
  4.  @Expose (serialize = false, deserialize = false) private String emailAddress;
  5.  private String password;
  6. }

如果你以new Gson()的方式创建Gson对象,toJson()方法和fromJson() 方法在序列化和反序列化的时候将会操作这4个属性。然而,如果你使用 Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create()来创建Gson对象,Gson 的 toJson() 和 fromJson() 方法将会排除掉 password 字段,这是因为 password 字段没有被注解 @Expose 所标记。 这个 Gson 对象同样会排除 lastName 和 emailAddress 字段,因为注解@Expose的属性 serialize 被设置成了 false。类似的,Gson 将会在反序列化时排除掉 emailAddress 字段,因为 deserialize被设置成了 false。

PS:

如果不希望有某些属性,也可以使用transient屏蔽,如:

transient int val;

SerializedName

  此注解作用在属性上,表明这个属性在序列化成Json的时候,需要将名字序列化成注解的value属性指定的值。

  这个注解将会覆盖任何的FieldNamingPolicy, 包括默认的命名策略。下面是一个介绍@SerializedName注解如何使用的例子:

  1. public class SomeClassWithFields {
  2.  @SerializedName("name") private final String someField;
  3.  private final String someOtherField;
  4.  public SomeClassWithFields(String a, String b) {
  5.  this.someField = a;
  6.  this.someOtherField = b;
  7.  }
  8. }

序列化结果是:{"name":"a","someOtherField":"b"}

Since

使用@Since注解去维护版本,比如你有一个REST的API,并且有多个版本的JSON,如果下一个版本JSON中增加了字段,但又不希望所有的版本都在使用这些字段的话,就可以使用

  1. public class Example33 {
  2. public static void main(String[] args) {
  3. Gson gson = new GsonBuilder().setVersion(2.0).create();
  4. String json = gson.toJson(new ExampleClass());
  5. System.out.println("Output for version 2.0...");
  6. System.out.println(json);
  7.  
  8. gson= new GsonBuilder().setVersion(1.0).create();
  9. json = gson.toJson(new ExampleClass());
  10. System.out.println("\nOutput for version 1.0...");
  11. System.out.println(json);
  12.  
  13. gson= new Gson();
  14. json = gson.toJson(new ExampleClass());
  15. System.out.println("\nOutput for No version set...");
  16. System.out.println(json);
  17. }
  18. }
  19.  
  20. class ExampleClass{
  21. String field= "field";
  22. // this is in version 1.0
  23. @Since(1.0) String newField1 = "field 1";
  24. // following will be included in the version 1.1
  25. @Since(2.0) String newField2 = "field 2";
  26. }

输出为:
Output for version 2.0...
{"field":"field","newField1":"field 1","newField2":"field 2"}

Output for version 1.0...
{"field":"field","newField1":"field 1"}

Output for No version set...
{"field":"field","newField1":"field 1","newField2":"field 2"}

Until

和Since相反,如果下一个版本JSON中删除了某个字段,就可以使用,原理同上。

使用注释之后,我们创建gson就需要用到

GsonBuilder

具体设置参数如下

  1. Gson gson = new GsonBuilder()
  2. .excludeFieldsWithoutExposeAnnotation() //不导出实体中没有用@Expose注解的属性
  3. .enableComplexMapKeySerialization() //支持Map的key为复杂对象的形式
  4. .serializeNulls().setDateFormat("yyyy-MM-dd HH:mm:ss:SSS")//时间转化为特定格式
  5. .setFieldNamingPolicy(FieldNamingPolicy.UPPER_CAMEL_CASE)//会把字段首字母大写,注:对于实体上使用了@SerializedName注解的不会生效.
  6. .setPrettyPrinting() //对json结果格式化.
  7. .setVersion(1.0)
  8.     .disableHtmlEscaping()//默认是GSON把HTML 转义的,但也可以设置不转义
  9. .serializeNulls()//把null值也转换,默认是不转换null值的,可以选择也转换
  10. .create();

PS:如果需要转换的类包括泛型,那么也需要用到TypeToken,通过这个类可以获取具体的类型

  1. public class ApiResult<T> {
  2. private int ret;
  3. private String msg;
  4. private T data;
  5.  
  6. public int getRet() {
  7. return ret;
  8. }
  9.  
  10. public void setRet(int ret) {
  11. this.ret = ret;
  12. }
  13.  
  14. public String getMsg() {
  15. return msg;
  16. }
  17.  
  18. public void setMsg(String msg) {
  19. this.msg = msg;
  20. }
  21.  
  22. public T getData() {
  23. return data;
  24. }
  25.  
  26. public void setData(T data) {
  27. this.data = data;
  28. }
  29.  
  30. }
  1. ApiResult<UserInfo> r = GsonUtils.parse(json, new TypeToken<ApiResult<UserInfo>>() {
  2. }.getType());

参考网站:

http://jiuyuehe.iteye.com/blog/1882800

http://shazhuzhu1.iteye.com/blog/974758

http://jackyrong.iteye.com/blog/2004374

http://blog.csdn.net/lk_blog/article/details/7685190

Android开源库--Gson谷歌官方json解析库的更多相关文章

  1. Android中的应用——谷歌官方Json分析工具Gson使用

    一个.Gson基本介绍 Gson(又称Google Gson)是Google公司公布的一个开放源码的Java库.主要用途为串行化Java对象为JSON字符串,或反串行化JSON字符串成Java对象. ...

  2. Android JSON 解析库的使用 - Gson 和 fast-json

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族 ...

  3. Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例

    Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例 继上篇json解析,我用了原生的json解析,但是在有些情况下我们不得不承认,一些优秀的json解析框架确实十分的 ...

  4. 常用json解析库比较及选择 fastjson & gson

    一.常用json解析库比较及选择 1.简介 fastjson和gson是目前比较常用的json解析库,并且现在我们项目代码中,也在使用这两个解析库. fastjson 是由阿里开发的,号称是处理jso ...

  5. fastjson是阿里巴巴的开源JSON解析库

    fastjson的API十分简洁. String text = JSON.toJSONString(obj); //序列化 VO vo = JSON.parseObject("{...}&q ...

  6. C++的Json解析库:jsoncpp和boost

    C++的Json解析库:jsoncpp和boost - hzyong_c的专栏 - 博客频道 - CSDN.NET C++的Json解析库:jsoncpp和boost 分类: 网络编程 开源库 201 ...

  7. C++的Json解析库:jsoncpp和boost(转)

    原文转自 http://blog.csdn.net/hzyong_c/article/details/7163589 JSON(JavaScript Object Notation)跟xml一样也是一 ...

  8. [转]C++的Json解析库:jsoncpp和boost

    JSON(JavaScript Object Notation)跟xml一样也是一种数据交换格式,了解json请参考其官网http://json.org,本文不再对json做介绍,将重点介绍c++的j ...

  9. 深入 Go 中各个高性能 JSON 解析库

    转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com/archives/535 其实本来我是没打算去看 JSON 库的性能问题的,但是最近我对 ...

随机推荐

  1. http协议了解

    在web应用中,服务器把网页的HTML代码发送给浏览器,让浏览器显示出来,浏览器和服务器之间的传输协议就是HTTP协议.HTTP是在网络上传输HTML的协议,用于浏览器和服务器之间的通信. 一个网页打 ...

  2. A类地址

    一个A类IP地址由1字节(每个字节是8位)的网络地址和3个字节主机地址组成,网络地址的最高位必须是“0”.A类IP的地址第一个字段范围是0~127,但是由于全0和全1的地址用作特殊用途,实际可指派的第 ...

  3. 清空html代码

    不要使用 $("XXX").html(""); 清空html代码块一般有两种方式: 1)非miniui等组件区块:$("#id").empt ...

  4. 2015-11-04 报表 (asp.net 部分)

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Scrap_p.aspx.cs& ...

  5. 周赛-Heros and Swords 分类: 比赛 2015-08-02 08:30 11人阅读 评论(0) 收藏

    Heros and Swords Time Limit: 6000/3000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) Su ...

  6. 编译ITK

    [2016年7月4周]编译ITK 1.下载必备文件 InsightToolkit-4.8.1.cmake 2.cmake编译 修改CMAKE_INSTALL_PREFIX配置到需要生成的目录下面去. ...

  7. 新注册域名greenopen.site,向专业道路进军

    新注册域名greenopen.site,向专业道路进军,欢迎访问!届时可以通过 greenopen.site jsxyhelu.github.io 或者jsxyhelu.cnblogs.com 访问本 ...

  8. Linux/Unix里,ln -s

    这是硬/软链接的命令ln -s 是创建软链接ln 是创建硬链接 你可以理解为:相当于windows下创建快捷方式一样,所以就不用太多解释了吧. ln -s /usr/lib/libX11.3 libX ...

  9. SharePoint自动化系列——Select-option标签的定位方法总结

    转载请注明出自天外归云的博客园:http://www.cnblogs.com/LanTianYou/ C#中通过Selenium定位页面上的select-option结构,尝试了以下几种方法,均没有生 ...

  10. Android中直播视频技术探究之---摄像头Camera视频源数据采集解析

    一.前言 在视频直播中一般都是两种视频数据源,一个是摄像头数据,一个是录制桌面数据,而一般来说美女妹子直播都是来自于摄像头数据,游戏直播都是录制桌面数据的,那么今天就来看看第一个数据源数据采集分析,A ...