如何在我想与JiBX绑定的类中保留我的using接口?

例:
我在Java中有这个非常简单的模型:

public interface A {
    B getB();
    void setB(B b);
}

public interface B {
    String getData();
    void setData(String data);
}

public class AImpl implements A {
    B b;

    @Override
    public B getB() {
        return b;
    }

    @Override
    public void setB(B b) {
        this.b = b;
    }
}

public class BImpl implements B {
    private String data;
    @Override
    public String getData() {
        return data;
    }

    @Override
    public void setData(String data) {
        this.data = data;
    }
}

以及此绑定文件:
<binding>
<mapping name="A"
         class="com.test.AImpl">
    <structure name="B" usage="optional" get-method="getB" set-method="setB"/>
</mapping>
<mapping name="B"
         class="com.test.BImpl">
    <value name="data" set-method="setData" get-method="getData" usage="optional"/>
</mapping>
</binding>

当我尝试运行代码时,出现以下异常:

java.lang.ClassFormatError:方法
在com / test / B类中有非法
修改器:0x1001

我试图在两个映射上都使用'abstract =“true”',只是为了获得此异常:

...由:
org.jibx.runtime.JiBXException:无法
访问绑定信息
com.test.A类确保绑定
已被编译...

我发现的唯一解决方案是让AImpl持有BImpl而不是B,并使getter返回BImpl且setter接收BImpl。这是非常错误的,因为它会完全破坏接口。

我该如何解决?我一直在发脾气,发脾气(真正的问题要复杂得多,并且JiBX隐式错误消息无济于事)-没有什么帮助。

这可以解决吗? JiBX真的那么令人讨厌吗(因为它要求我放弃所有接口编程?)

请不要回答“use AbstractB”,因为它是相同的问题,仅删除了一个级别。

最佳答案

在映射中,您应该能够使用“create-type”属性来指定JiBX应该为具有接口类型的bean属性实例化的具体类。我经常将其用于收藏属性。例如,您可以告诉JiBX实例化 java.util.Set 类型的属性的 java.util.HashSet 。但是我相信它对于非收集属性同样有效。您的映射如下所示:

<mapping class="com.mypackage.AImpl" name="A">
  <structure get-method="getB" set-method="setB" create-type="com.mypackage.BImpl">
    ...
  </structure>
  ...
</mapping>

JiBX将调用no-arg构造函数来创建B对象。另外,如果需要精美的实例化逻辑,则可以使用工厂或自定义的序列化器/解串器。有关详细信息,请参见this reference page

10-07 23:16