Gson教程十三:模型版本化、日期格式化、漂亮输出

由于Gson Tutorial Series系列教程关于这三部分没有开放,因此自己完成本部分内容,有些内容翻译自相关API,有些内容自己所创,由于能力有限,如有错误还请指出,以后网站相关内容公布后,再行翻译至此

模型版本化

Gson可以通过@Since注解以及@Until注解来为你的Java对象设置版本控制,如此,则你的模型类里面被以上两个注解标记了的成员变量,将只有符合特定版本范围内时才会被序列化和反序列化。

这两个注解只有在通过GsonBuilder创建的Gson实例上才有效,我们需要通过GsonBuilder.setVersion(double)来激活。

@Since

该注解指示出某一成员或类型在这一特定的版本号之后才存在。例如有下面的模板类:

public class User {
   private String firstName;
   private String lastName;
   @Since(1.0) private String emailAddress;
   @Since(1.0) private String password;
   @Since(1.1) private Address address;
 }

如果你使用new Gson()创建Gson实例,那么toJson()fromJson()不会使用它们。然而,如果你使用Gson gson = new GsonBuilder().setVersion(1.0).create()来创建Gson实例,那么toJson()fromJson()方法将排除address域,因为它的版本号被设置为了1.1

@Until

@Until注解为某一成员或类型指定了一个版本号,代表该成员或类型在该版本号之前才存在。
稍微改变User模型:

 public class User {
   private String firstName;
   private String lastName;
   @Until(1.1) private String emailAddress;
   @Until(1.1) private String password;
 }

现在,我们使用Gson gson = new GsonBuilder().setVersion(1.2).create()来创建Gson实例,toJson()fromJson()方将排除emailAddresspassword域,这是因为传入的版本号为1.2,超过了我们给定的1.1

格式化日期和时间

正如你所想到的,该功能也需要配置GsonBuilder。Gson为我们提供了三个重载的方法。

  • setDateFormat(String pattern):pattern遵循SimpleDateFormat类的惯例。
  • setDateFormat(int style):style必须是DateFormat的一个常量。
  • setDateFormat(int dateStyle, int timeStyle):类似于上面的,只不过将日期和时间分开了。

漂亮输出

序列化得到的JSON是无空格的,所有字符都密密麻麻挤在了一起,这虽然节约空间,但对于人的理解却不友好。只需相应的设置GsonBuilder即可:

Gson gson = new GsonBuilder().setPrettyPrinting().create();
String jsonOutput = gson.toJson(someObject);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.概述2.Gson的目标3.Gson的性能和扩展性4.Gson的使用者5.如何使用Gson 通过Maven来使用...
    人失格阅读 14,353评论 2 18
  • 为了更好的学习Gson,特将Gson User Guide翻译如下。由于本人英文水平有限,如有错误,还请指正,谢谢...
    WeberLisper阅读 6,910评论 0 6
  • 我是一个很喜欢看电影的人,对我来说有些电影的意义,不仅仅是电影这么简单,更重要的是我在这描述如同梦境一般虚幻而真实...
    腾阳阅读 2,344评论 8 25
  • 既然加入我们了养森,我希望大家都能拿出最好的状态,最积极的状态出来 如果我想拉你,你不把手伸出来给我,我也想拉也拉...
    杨绵羊羊阅读 199评论 0 0