Gson - Suporte de Controle de Versão

Gson fornece @Sinceanotação para controlar a serialização / desserialização Json de uma classe com base em suas várias versões. Considere a seguinte classe com suporte para controle de versão. Nesta aula, definimos inicialmente duas variáveisrollNo e name e mais tarde, adicionamos verifiedcomo uma nova variável. Usando @Since, definimosrollNo e name a partir da versão 1.0 e verificado para ser da versão 1.1.

class Student { 
   @Since(1.0) 
   private int rollNo; 
   
   @Since(1.0) 
   private String name; 
   
   @Since(1.1) 
   private boolean verified;  
}

GsonBuilder fornece o setVersion() método para serializar essa classe com controle de versão.

GsonBuilder builder = new GsonBuilder(); 
builder.setVersion(1.0);   
Gson gson = builder.create();

Exemplo

Vamos ver um exemplo de suporte a versionamento em ação. Crie um arquivo de classe Java chamadoGsonTester em C: \> GSON_WORKSPACE.

Arquivo - GsonTester.java

import com.google.gson.Gson; 
import com.google.gson.GsonBuilder; 
import com.google.gson.annotations.Since;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      GsonBuilder builder = new GsonBuilder(); 
      builder.setVersion(1.0);   
      Gson gson = builder.create();
      
      Student student = new Student(); 
      student.setRollNo(1); 
      student.setName("Mahesh Kumar"); 
      student.setVerified(true);  
      
      String jsonString = gson.toJson(student); 
      System.out.println(jsonString);  
      
      gson = new Gson();     
      jsonString = gson.toJson(student); 
      System.out.println(jsonString); 
   }      
} 

class Student { 
   @Since(1.0) 
   private int rollNo; 
   
   @Since(1.0) 
   private String name; 
   
   @Since(1.1) 
   private boolean verified;   
   
   public int getRollNo() { 
      return rollNo; 
   }  
   
   public void setRollNo(int rollNo) { 
      this.rollNo = rollNo; 
   } 
   
   public String getName() { 
      return name; 
   } 
   
   public void setName(String name) { 
      this.name = name; 
   }
   
   public void setVerified(boolean verified) { 
      this.verified = verified; 
   }  
   
   public boolean isVerified() { 
      return verified; 
   } 
}

Verifique o resultado

Compile as classes usando javac compilador da seguinte forma -

C:\GSON_WORKSPACE>javac GsonTester.java

Agora execute o GsonTester para ver o resultado -

C:\GSON_WORKSPACE>java GsonTester

Verifique a saída.

{"rollNo":1,"name":"Mahesh Kumar"} 
{"rollNo":1,"name":"Mahesh Kumar","verified":true}