您的位置:

探究Gson转对象

一、Gson简介

Gson是Google提供的用来转换Java对象与JSON数据格式的Java类库。它可以将JSON数据转换为Java对象,也可以将Java对象转换为JSON数据。Gson的作用类似于Java中的序列化和反序列化。

Gson提供了简单易用的API来实现JSON数据的序列化和反序列化,同时也提供了高级功能,如通过注解自定义序列化和反序列化,以及通过TypeAdapter在某些场景下更精细地控制序列化和反序列化过程。

二、Gson基本用法

使用Gson将Java对象转换为JSON数据格式的代码如下:

Gson gson = new Gson();
String json = gson.toJson(object); //object为待转换的Java对象

将JSON数据格式转化为Java对象的代码如下:

Gson gson = new Gson();
Object object = gson.fromJson(json, Object.class); //json为待转换的JSON数据

其中,Gson提供了很多toJson()和fromJson()的重载方法,可以根据不同的需求进行转换。例如,toJson()方法还可以接受一个Writer对象,用于将JSON数据格式输出到文件或网络流中。

三、Gson注解

使用注解可以更精细地控制Gson的序列化和反序列化过程。Gson提供了以下注解:

  • @SerializedName:用于将Java对象的字段名与JSON中的字段名相对应。
  • @Expose:用于标识哪些Java对象的字段需要进行序列化和反序列化。
  • @JsonAdapter:用于指定通过TypeAdapter自定义的序列化和反序列化方式。

举个例子,下面是一个使用@SerializedName注解的示例:

public class Person {
  @SerializedName("name")
  private String mName;
  @SerializedName("age")
  private int mAge;
}

在这个示例中,Person类中的成员变量mName和mAge分别对应JSON格式中的"name"和"age"字段。

四、Gson TypeAdapter

有时候,在处理JSON格式数据时,我们需要针对某些数据类型进行更加细致的转换。例如,Gson默认将Date类型转换为毫秒数,而我们可能需要将其转换为指定的日期格式。这时候,我们可以使用TypeAdapter来自定义转换方式。

下面是一个使用TypeAdapter自定义转换Long型时间戳为Java Date类型的示例:

public class DateTypeAdapter extends TypeAdapter {
 
  @Override
  public void write(JsonWriter out, Date value) throws IOException {
    if (value == null) {
      out.nullValue();
      return;
    }
    out.value(value.getTime());
  }
 
  @Override
  public Date read(JsonReader in) throws IOException {
    if (in.peek() == JsonToken.NULL) {
      in.nextNull();
      return null;
    }
    return new Date(in.nextLong());
  }
}

  

以上代码定义了一个名为DateTypeAdapter的TypeAdapter,实现了将Java Date类型转换为Long型时间戳的功能。

下面是一个使用自定义TypeAdapter的示例:

public class Person {
  private String mName;
  @JsonAdapter(DateTypeAdapter.class)
  private Date mBirthday;
}

在这个示例中,Person类中的mBirthday字段通过@JsonAdapter注解指定了DateTypeAdapter作为转换方式。

五、Gson高级用法

除上面说到的基础功能和注解功能外,Gson还提供了很多高级用法,如泛型支持、json转换Promise、支持自定义Instance Creators等。

关于Gson的更多高级用法,可以查看官方文档。

六、总结

本文从Gson的基本用法、注解、TypeAdapter和高级用法四个方面对Gson进行了详细的介绍。其中,注解和TypeAdapter可以帮助我们更精细地控制Gson的序列化和反序列化过程,而高级用法则可以满足一些更为复杂的需求。