Gson има специална обработка за десериализация на някои еднокомпонентни масиви в тип без масив. Например int data = gson.fromJson("[3]", int.class);
ще присвои int стойност 3 на данни.
Разбира се, не се изисква десериализация на еднокомпонентен масив в тип без масив. Например, предишният пример може да бъде десериализиран като int[] data = gson.fromJson("[3]", int[].class);
.
Gson също така често ще десериализира стойност, която не е String, в String, когато бъде попитана. Прилагайки това към първия пример, String data = gson.fromJson("[3]", String.class);
работи също толкова добре.
Имайте предвид, че не работи да кажете на Gson да десериализира първия пример като тип Object. Object data = gson.fromJson("[3]", Object.class);
води до изключение за анализ, оплакващо се, че [3] не е примитивен.
Приложено към примера в първоначалния въпрос по-горе, ако е приемливо да се третират всички стойности като низове, тогава десериализацията става проста.
// output:
// hello 1 2
// world 3 2
public class Foo
{
static String jsonInput =
"[" +
"[\"hello\",1,[2]]," +
"[\"world\",3,[2]]" +
"]";
public static void main(String[] args)
{
Gson gson = new Gson();
String[][] data = gson.fromJson(jsonInput, String[][].class);
for (String[] data2 : data)
{
for (String data3 : data2)
{
System.out.print(data3);
System.out.print(" ");
}
System.out.println();
}
}
}
За съжаление, с Gson не успях да разбера прост подход за десериализация, който би позволил "по-добро" свързване към по-специфични и смесени типове в масив, тъй като Java не предоставя синтаксис за дефиниране на масив от смесен тип. Например предпочитаният тип колекция в оригиналния въпрос може да е List<List<String, int, List<int>>>
, но това не е възможно да се дефинира в Java. Така че трябва да се задоволите с List<List<String>> (or String[][])
или да се обърнете към подход с по-„ръчно“ анализиране.
(Да, Java позволява декларация на тип на List<List<Object>>
, но Object
не е достатъчно специфичен тип, за да се десериализира смислено. Освен това, както беше обсъдено, опитът за десериализиране [3] на Object води до изключение от анализ.)
Малка актуализация: Наскоро трябваше да десериализирам някакъв небрежен JSON, който включва структура, която не е много различна от тази в първоначалния въпрос. В крайна сметка просто използвах персонализиран десериализатор, за да създам обект от разхвърляния JSON масив. Подобно на следния пример.
// output:
// [{MyThreeThings: first=hello, second=1, third=[2]},
// {MyThreeThings: first=world, second=3, third=[4, 5]}]
import java.lang.reflect.Type;
import java.util.Arrays;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.JsonArray;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonDeserializer;
import com.google.gson.JsonElement;
import com.google.gson.JsonParseException;
public class FooToo
{
static String jsonInput =
"[" +
"[\"hello\",1,[2]]," +
"[\"world\",3,[4,5]]" +
"]";
public static void main(String[] args)
{
GsonBuilder gsonBuilder = new GsonBuilder();
gsonBuilder.registerTypeAdapter(MyThreeThings.class, new MyThreeThingsDeserializer());
Gson gson = gsonBuilder.create();
MyThreeThings[] things = gson.fromJson(jsonInput, MyThreeThings[].class);
System.out.println(Arrays.toString(things));
}
}
class MyThreeThings
{
String first;
int second;
int[] third;
MyThreeThings(String first, int second, int[] third)
{
this.first = first;
this.second = second;
this.third = third;
}
@Override
public String toString()
{
return String.format(
"{MyThreeThings: first=%s, second=%d, third=%s}",
first, second, Arrays.toString(third));
}
}
class MyThreeThingsDeserializer implements JsonDeserializer<MyThreeThings>
{
@Override
public MyThreeThings deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context)
throws JsonParseException
{
JsonArray jsonArray = json.getAsJsonArray();
String first = jsonArray.get(0).getAsString();
int second = jsonArray.get(1).getAsInt();
JsonArray jsonArray2 = jsonArray.get(2).getAsJsonArray();
int length = jsonArray2.size();
int[] third = new int[length];
for (int i = 0; i < length; i++)
{
int n = jsonArray2.get(i).getAsInt();
third[i] = n;
}
return new MyThreeThings(first, second, third);
}
}
Ръководството за потребителя на Gson обхваща обработката на десериализация на колекции от смесени типове с подобен пример като този в раздела "Сериализиране и десериализиране на колекция с обекти от произволни типове".
person
Programmer Bruce
schedule
02.06.2011