2012-08-07 126 views
0

我目前正在研究一种使用泛型并且很复杂的模型。我明白类似的问题已经得到解答,但他们没有一个明显回答我的问题。使用Jackson对Java泛型进行序列化和反序列化:StackOverflowError

这里是我的模型:

@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = As.WRAPPER_OBJECT, property = "type") 
@JsonSubTypes(
       { 
        @Type(value = Cls2.class, name = "Cls2") 
       }) 
abstract class Cls1<T> implements Serializable 
{ 
    private T myObj; 

    public T getMyObj() 
    { 
     return myObj; 
    } 

    public Cls1(T obj) 
    { 
     myObj = obj; 
    } 
    @JsonTypeName("Cls2") 
    public static class Cls2<E extends Int1> extends Cls1<E> implements Serializable 
    { 
     public Cls2() 
     { 
      super(null); 
     } 
    } 
} 

@JsonTypeName("ChildContainer") 
class ChildContainer extends ParentContainer<OtherBean> 
{ 

} 

@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = As.WRAPPER_OBJECT, property = "type") 
@JsonSubTypes(
       { 
        @Type(value = ChildContainer.class, name = "ChildContainer") 
       }) 
class ParentContainer<T extends RootBean> implements Int1 
{ 

} 

@JsonTypeName("OtherBean") 
class OtherBean extends RootBean 
{ 

} 

@JsonTypeName("RootBean") 
class RootBean implements Int1 
{ 

} 

@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = As.WRAPPER_OBJECT, property = "type") 
@JsonSubTypes(
       { 
        @Type(value = RootBean.class, name = "RootBean"), 
        @Type(value = OtherBean.class, name = "OtherBean") 
       }) 
interface Int1 extends Serializable 
{ 

} 

我的目标是序列化和使用杰克逊如下deserialze:

public static void main(String[] args) throws Exception 
    { 

     Cls2<ChildContainer> req = new Cls2<ChildContainer>(); 

     File file = new File("==some-file-path=="); 

     ObjectMapper mapper = new ObjectMapper(); 

     mapper.writeValue(file, req); 

     //read it back using mapper.readValue(file, clazz) --Not sure about this 
    } 

我序列化过程中得到以下java.lang.StackOverflowError的:

Exception in thread "main" java.lang.StackOverflowError 
    at java.lang.Class.getDeclaringClass(Native Method) 
    at org.codehaus.jackson.map.type.TypeBindings._resolveBindings(TypeBindings.java:290) 
    at org.codehaus.jackson.map.type.TypeBindings._resolve(TypeBindings.java:221) 
    at org.codehaus.jackson.map.type.TypeBindings.findType(TypeBindings.java:138) 
    at org.codehaus.jackson.map.type.TypeFactory._fromVariable(TypeFactory.java:951) 
    at org.codehaus.jackson.map.type.TypeFactory._constructType(TypeFactory.java:493) 
    at org.codehaus.jackson.map.type.TypeFactory.findTypeParameters(TypeFactory.java:423) 
    at org.codehaus.jackson.map.type.TypeFactory.findTypeParameters(TypeFactory.java:395) 
    at org.codehaus.jackson.map.type.TypeBindings._resolveBindings(TypeBindings.java:299) 
    at org.codehaus.jackson.map.type.TypeBindings._resolveBindings(TypeBindings.java:290) 
    at org.codehaus.jackson.map.type.TypeBindings._resolve(TypeBindings.java:221) 
    at org.codehaus.jackson.map.type.TypeBindings.findType(TypeBindings.java:138) 
    at org.codehaus.jackson.map.type.TypeFactory._fromVariable(TypeFactory.java:951) 
    at org.codehaus.jackson.map.type.TypeFactory._constructType(TypeFactory.java:493) 
    at org.codehaus.jackson.map.type.TypeFactory.findTypeParameters(TypeFactory.java:423) 
    at org.codehaus.jackson.map.type.TypeFactory.findTypeParameters(TypeFactory.java:395) 
    at org.codehaus.jackson.map.type.TypeBindings._resolveBindings(TypeBindings.java:299) 
    at org.codehaus.jackson.map.type.TypeBindings._resolveBindings(TypeBindings.java:290) 

任何帮助深表谢意。

+0

从错误消息或调试器中捕获堆栈(重复)部分,肯定有助于确定发生圆形的位置。 – 2012-08-07 16:18:37

+0

@AndrzejDoyle我已经用stacktrace更新了帖子 – Chris 2012-08-07 16:21:31

+1

解析类型中有一个无限递归,这似乎是Jackson中的一个bug。尝试将'Cls2'提取到独立的类中。 – BalusC 2012-08-07 16:24:17

回答

1

stacktrace建议解决Cls2类型的无限递归,它扩展了它本身嵌套的类。这似乎是Jackson中的一个角落案例错误(report it!)。与此同时,将Cls2提取到独立类中,而不是将它嵌套在其超类中,可以解决此问题。

相关问题