gson的@Expose注解和@SerializedName注解

1.使用@Expose可以区分实体中不想被序列化的属性

@Expose标签的2个属性. 

  1.1 deserialize
 (boolean)反序列化 默认 true
     1.2  serialize  (boolean) 序列化 默认 true

   使用  new  GsonBuilder().excludeFieldsWithoutExposeAnnotation().create(); 创建Gson对象,没有@Expose注释的属性将不会被序列化

 

public   class  User {

 

@Expose

private String username;

@Expose(serialize=false)

private int age ;

 

private List<String> list;

 

public User(String username, int age) {

super();

this.username username;

this.age age;

}

 

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username username;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age age;

}

public List<String> getList() {

return list;

}

public void setList(List<String> list) {

this.list list;

}

 

public static void main(String []args){

User user new User("lemon",27);

List<String> list new ArrayList<String>();

list.add("l1");

list.add("l2");

user.setList(list);

Gson g1 new Gson();

//使用 new Gson();

System.out.println(g1.toJson(user)); //{"username":"lemon","age":27,"list":["l1","l2"]}

//使用 new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();

Gson g2 new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();

System.out.println(g2.toJson(user)); //{"username":"lemon"}

  }

}


2.使用@ SerializedName标签定义属性序列化 后的名字

@Expose

@SerializedName("name")

private String username;


public static void main(String []args){

User user new User("lemon",27);

List<String> list new ArrayList<String>();

list.add("l1");

list.add("l2");

user.setList(list);

Gson g1 new Gson();

//使用 new Gson();

//{"name":"lemon","age":27,"list":["l1","l2"]}

System.out.println(g1.toJson(user)); 

//使用 new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();

Gson g2 new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();

//{"name":"lemon"}

System.out.println(g2.toJson(user)); 

}


补充:简单方式:排除部分不序列化的属性(特别是循环引用的)可以使用关键字:transient。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值