序列化和反序列化通用类型
当您调用toJson(obj)时,Gson会调用obj.getClass()以获取有关要序列化的字段的信息。同样,通常可以在fromJson(json,MyClass.class)方法中传递MyClass.class对象。如果对象是非泛型类型,则可以正常工作。但是,如果对象属于通用类型,则由于Java
Type Erasure,通用类型信息会丢失。这是说明要点的示例:
class Foo<T> { T value;}Gson gson = new Gson();Foo<Bar> foo = new Foo<Bar>();gson.toJson(foo); // May not serialize foo.value correctlygson.fromJson(json, foo.getClass()); // Fails to deserialize foo.value as Bar上面的代码无法将值解释为Bar类型,因为Gson调用list.getClass()来获取其类信息,但是此方法返回的是原始类Foo.class。这意味着Gson无法知道这是Foo类型的对象,而不仅仅是纯Foo。
您可以通过为泛型类型指定正确的参数化类型来解决此问题。您可以通过使用TypeToken类来实现。
Type fooType = new TypeToken<Foo<Bar>>() {}.getType(); gson.toJson(foo, fooType);gson.fromJson(json, fooType);我有Parent类,而它是child类,其中一些具有List类型。像这个父类一样,我有30个文件。我这样解决了。
Gson gson = new Gson();JSonObject jsonObj = new JSonObject(object.get(DO_SERVICES).toString());Type type = new TypeToken<MyDto>() {}.getType();servDto = gson.fromJson(jsonObj.toString(),type);最重要的是,我无法在Android Studio的本地测试中重现此错误。
仅当我生成签名的apk并将应用程序发布到PlayStore中时,该应用程序停止,并且报告说无法将linkedTreeMap投射到myclass时,才弹出此问题。
我很难在本地测试(包括“调试”模式)中重现相同的结果。



