2

使用 ByteBuddy,我想为具有包私有默认构造函数的类型创建代理。那是类型:

public class Foo {

    Foo() {
    }
}

这就是我的代理创建和实例化代码:

public class CreateAndExecuteProxy {

    public static void main(String[] args) throws Exception {
        Constructor<?> superConstructor = Foo.class.getDeclaredConstructor();

        Class<? extends Foo> proxyType = new ByteBuddy()
                .subclass( Foo.class, ConstructorStrategy.Default.NO_CONSTRUCTORS )
                .defineConstructor( Visibility.PUBLIC )
                .intercept( MethodCall.invoke( superConstructor ).onSuper() )
                .make()
                .load( CreateAndExecuteProxy.class.getClassLoader(), ClassLoadingStrategy.Default.WRAPPER)
                .getLoaded();

        Foo foo = proxyType.newInstance();
    }
}

所以我试图将公共默认构造函数添加到我的代理类型,拦截它的调用并委托给超类型构造函数。IllegalAccessException虽然在生成的构造函数中失败了:

Exception in thread "main" java.lang.IllegalAccessError:
tried to access method com.example.proxy.test.Foo.&lt;init&gt;()V from class com.example.proxy.test.Foo$ByteBuddy$65mxf95M
  com.example.proxy.test.Foo$ByteBuddy$65mxf95M.&lt;init&gt;(Unknown Source)
  ...
  at java.lang.Class.newInstance(Class.java:442)
  at com.example.proxy.test.CreateAndExecuteProxy.main(CreateAndExecuteProxy.java:33)

由于代理与代理类在同一个包中,我不清楚为什么该调用失败。我在这里做错了什么?是否有另一种方法可以让代理调用具有默认可见性的超级构造函数?

4

1 回答 1

3

这些类由两个不同的类加载器加载。请将您的策略​​更改为 INJECTION 并尝试。

ClassLoadingStrategy.Default.INJECTION

于 2016-02-17T12:01:59.720 回答