使用 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.<init>()V from class com.example.proxy.test.Foo$ByteBuddy$65mxf95M
com.example.proxy.test.Foo$ByteBuddy$65mxf95M.<init>(Unknown Source)
...
at java.lang.Class.newInstance(Class.java:442)
at com.example.proxy.test.CreateAndExecuteProxy.main(CreateAndExecuteProxy.java:33)
由于代理与代理类在同一个包中,我不清楚为什么该调用失败。我在这里做错了什么?是否有另一种方法可以让代理调用具有默认可见性的超级构造函数?