2

ByteBuddy 0.6.15 から 1.2.3 にアップグレードしていますが、「Illegal interface type」という例外が発生します。私はそれをこの短いコードに要約することができました:

@Test
public void bytebuddy() {
    new ByteBuddy()
            .subclass(Object.class)
            .implement(MyInterface.class)
            .make();
}

interface MyInterface {
    void doSomething();
}

0.6.15 ではこれが機能していましたが、1.2.3 では例外が発生しました。以下を参照してください。

インターフェイスのどこが違法なのか、それを機能させるために何を変更する必要があるのか​​ わかりません。最初はメソッドで何もしていないからかなと思ったのですdoSomethingが、インターフェースが完全に空の場合も同じエラーが発生します。

java.lang.IllegalStateException: Illegal interface type interface nl.jqno.equalsverifier.internal.InstantiatorTest$MyInteface for class net.bytebuddy.renamed.java.lang.Object$ByteBuddy$qViwRZJu

  at net.bytebuddy.dynamic.scaffold.InstrumentedType$Default.validated(InstrumentedType.java:694)
  at net.bytebuddy.dynamic.scaffold.MethodRegistry$Default.prepare(MethodRegistry.java:530)
  at net.bytebuddy.dynamic.scaffold.subclass.SubclassDynamicTypeBuilder.make(SubclassDynamicTypeBuilder.java:153)
  at net.bytebuddy.dynamic.DynamicType$Builder$AbstractBase$Delegator.make(DynamicType.java:2508)
  at nl.jqno.equalsverifier.internal.InstantiatorTest.bytebuddy(InstantiatorTest.java:43)
  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  at java.lang.reflect.Method.invoke(Method.java:497)
  at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
  at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
  at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
  at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
  at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
  at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
  at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
  at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
  at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
  at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
  at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
  at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
  at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
  at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
  at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
  at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:234)
  at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:74)
  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  at java.lang.reflect.Method.invoke(Method.java:497)
  at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)
4

1 に答える 1

3

バージョン 1.* では、Byte Buddy によって明示的な検証が追加され、エラーの診断が容易になりました。あなたの場合、別のパッケージにあるクラスからパッケージ プライベート インターフェイスを拡張します。これは、実行時にインターフェイスが実装クラスに表示されないことを意味し、IllegalAccessError最終的には.

インターフェイスを に設定するとpublic、例が機能するはずです。または、生成されたクラスをインターフェースのパッケージに入れることもできます。これは、インターフェイスを直接サブクラス化すると自動的に発生しますnew ByteBuddy().subclass(MyInteface.class)。Byte Buddy は、提供されたクラスがインターフェースであることを発見し、それを実装します。ただし、この場合、暗黙的な名前はインターフェイスと同じパッケージに存在する名前になります。

最後に、型の検証により、実行時のオーバーヘッドがいくらか発生します。new ByteBuddy().with(TypeValidation.DISABLED)単体テストではなく本番環境で理想的に行うべきことを設定することで、検証を無効にすることができます。

最後に、単体テストについては何も違法ではありません。文言が間違っていたため、例外メッセージをinvisibleに変更しました。

于 2016-03-05T10:15:02.507 に答える