gson的 Expose注解和 SerializedName注解

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

@Expose标签的2个属性. 

1.1deserialize (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));

}

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

原文地址:https://www.cnblogs.com/skinchqqhah/p/10350607.html

时间: 2024-10-18 01:29:18

gson的 Expose注解和 SerializedName注解的相关文章

通透[email&#160;protected]注解、@SerializedName、解析json数据

在讲如何解析数据之前,先描述一下gson中的两个注解@Expose和@SerializedName. @Expose注解的作用:区分实体中不想被序列化的属性,其自身包含两个属性deserialize(反序列化)和serialize(序列化),默认都为true. 使用 new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();创建Gson对象,没有@Expose注释的属性将不会被序列化.. private class Use

@SerializedName注解

在Android中解析Gson解析json数据是很方便快捷的,可以直接将json数据解析成java对象或者集合. Gson解析json的方法我这里就不详细说明了,网上一大把的例子,我这里主要说一下使用@SerializedName进行注解的情况. 使用Gson解析json成对象时默认的是将json里对应字段的值解析到java对象里对应字段的属性里面.然后我们经常会遇到我们自己定义的java对象里的属性名跟json里的字段名是不一样的,这种情况怎么办呢,这时我们就可以使用@SerializedNa

@SerializedName注解的意义

本文转自http://blog.csdn.net/jiayi_yao/article/details/51057267,感谢原作者! 1 { 2 "id":"1" 3 "n":"kyoya" 4 "p":"123456" 5 "s":"0" 6 } 一段需要解析的json 1 public class User{ 2 private String

springMVC学习笔记(二)-----注解和非注解入门小程序

最近一直在做一个电商的项目,周末加班,忙的都没有时间更新博客了.终于在上周五上线了,可以轻松几天了.闲话不扯淡了,继续谈谈springMvc的学习. 现在,用到SpringMvc的大部分使用全注解配置,但全注解配置也是由非注解发张而来的.所以,今天就谈谈springMvc最基础的注解和非注解的配置以及开发模式. 一:基础环境准备 1.功能需求:一个简单的商品列表查询 2.开发环境:eclipse,java1.7,springmvc版本:3.2 3.springMvc所需jar包(一定包括spri

JavaEE开发之Spring中的条件注解、组合注解与元注解

上篇博客我们详细的聊了<JavaEE开发之Spring中的多线程编程以及任务定时器详解>,本篇博客我们就来聊聊条件注解@Conditional以及组合条件.条件注解说简单点就是根据特定的条件来选择Bean对象的创建.条件注解就是可以根据不同的条件来做出不同的事情.在Spring中条件注解可以说是设计模式中状态模式的一种体现方式,同时也是面向对象编程中多态的应用部分.而组合注解就是将现有的注解进行组合.下方会给出具体的介绍和实例. 一.条件注解[email protected] 本篇博客的本部分

java 自定义注解以及获得注解的值

1.自定义注解 import java.lang.annotation.*; @Documented @Target(ElementType.FIELD) @Inherited @Retention(RetentionPolicy.RUNTIME ) public @interface MyAnno { /** * 是否能为null * @return */ boolean isCanNull() default true; /** * 是否能为空字符串 * @return */ boolean

Java 注解入门实例 &amp;&amp; 注解传参

参考 概念:java提供了一种原程序中的元素关联任何信息和任何元数据的途径和方法 JDK内置系统注解: @Override 用于修饰此方法覆盖了父类的方法; @Deprecated 用于修饰已经过时的方法; @Suppvisewarnings 用于通知java编译器禁止特定的编译警告. 注解按照运行机制划分 源码注解:注解只在源码中存在,编译成.class文件就不存在了: 编译时注解:注解在源码和.class文件中都存在(例:JDK自带注解): 运行时注解:在运行阶段还起作用,甚至会影响运行逻辑

【SpringMVC学习03】SpringMVC中注解和非注解方式下的映射器和适配器总结

从上一篇的springmvc入门中已经看到,springmvc.xml中的配置了映射器和适配器,是使用非注解的方式来配置的,这是非注解方式的一种,这里再复习一下: 1. 非注解方式 1.1 处理器适配器 上一节中使用的处理器适配器是:org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter.即: SimpleControllerHandlerAdapter适配器能执行实现了Controller接口的Handler,所以我

Java注解(自定义注解、view注入)

注解这东西虽然在jdk1.5就加进来了,但他的存在还是因为使用Afinal框架的view注入才知道的.一直觉得注入特神奇,加了一句就可以把对应view生成了. 下面我们来认识一下注解这个东西 一.注解相关知识 注解相当于一种标记,在javac编译器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事.标记可以加在包,类,字段,方法,方法的参数以及局部变量上. 1.元注解:作用是负责注解其他注解.Java5.0定义了4个标准的meta-annotati