Gson - Associazione dati

L'API di associazione dati viene utilizzata per convertire JSON in e da POJO (Plain Old Java Object) utilizzando la funzione di accesso alle proprietà o utilizzando le annotazioni. È di due tipi.

  • Primitives Data Binding - Converte JSON in e da Java Maps, elenchi, stringhe, numeri, booleani e oggetti NULL.

  • Objects Data Binding - Converte JSON in e da qualsiasi tipo JAVA.

Gson legge / scrive JSON per entrambi i tipi di associazioni di dati. Il data binding è analogo al parser JAXB per XML.

Primitive Data Binding

Il data binding delle primitive si riferisce alla mappatura di JSON ai tipi di dati JAVA Core e alle raccolte integrate. Gson fornisce vari adattatori integrati che possono essere utilizzati per serializzare / deserializzare i tipi di dati primitivi.

Esempio

Vediamo il primitivo data binding in azione. Qui mapperemo i tipi di base JAVA direttamente in JSON e viceversa.

Crea un file di classe Java denominato GsonTester in C:\>Gson_WORKSPACE.

File − GsonTester.java

import java.util.Arrays; 
import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Gson gson = new Gson();  
      String name = "Mahesh Kumar"; 
      long rollNo = 1; 
      boolean verified = false; 
      int[] marks = {100,90,85};  
      
      //Serialization 
      System.out.println("{"); 
      System.out.println("name: " + gson.toJson(name) +","); 
      System.out.println("rollNo: " + gson.toJson(rollNo) +","); 
      System.out.println("verified: " + gson.toJson(verified) +","); 
      System.out.println("marks:" + gson.toJson(marks)); 
      System.out.println("}");  
      
      //De-serialization 
      name = gson.fromJson("\"Mahesh Kumar\"", String.class); 
      rollNo = gson.fromJson("1", Long.class); 
      verified = gson.fromJson("false", Boolean.class); 
      marks = gson.fromJson("[100,90,85]", int[].class);  
      
      System.out.println("name: " + name); 
      System.out.println("rollNo: " + rollNo); 
      System.out.println("verified: " +verified); 
      System.out.println("marks:" + Arrays.toString(marks)); 
   } 
}

Verifica il risultato

Compila le classi usando javac compilatore come segue -

C:\GSON_WORKSPACE>javac GsonTester.java

Ora esegui il file GsonTester per vedere il risultato -

C:\GSON_WORKSPACE>java GsonTester

Verifica l'output.

{ 
   name: "Mahesh Kumar", 
   rollNo: 1, 
   verified: false, 
   marks:[100,90,85] 
} 

name: Mahesh Kumar 
rollNo: 1 
verified: false 
marks:[100, 90, 85]