根据文档:
[ java.lang.reflect.]Proxy提供了用于创建动态代理类和实例的静态方法,它还是由这些方法创建的所有动态代理类的超类。
该newProxyMethod方法(负责生成动态代理)具有以下签名:
public static Object newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h) throws IllegalArgumentException
不幸的是,这阻止了人们生成扩展特定抽象类的动态代理(而不是实现特定接口)。考虑到java.lang.reflect.Proxy“所有动态代理的超类”,这是有道理的,因此可以防止另一个类成为超类。
因此,是否有其他替代方法java.lang.reflect.Proxy可以生成从特定抽象类继承的动态代理,从而将对抽象方法的所有调用重定向到调用处理程序?
例如,假设我有一个抽象类Dog:
public abstract class Dog { public void bark() { System.out.println("Woof!"); } public abstract void fetch(); }
有没有可以让我做以下事情的课程?
Dog dog = SomeOtherProxy.newProxyInstance(classLoader, Dog.class, h); dog.fetch(); // Will be handled by the invocation handler dog.bark(); // Will NOT be handled by the invocation handler
可以使用Javassist(请参见ProxyFactory)或CGLIB来完成。
亚当使用Javassist的示例:
我(Adam Paynter)使用Javassist编写了以下代码:
ProxyFactory factory = new ProxyFactory(); factory.setSuperclass(Dog.class); factory.setFilter( new MethodFilter() { @Override public boolean isHandled(Method method) { return Modifier.isAbstract(method.getModifiers()); } } ); MethodHandler handler = new MethodHandler() { @Override public Object invoke(Object self, Method thisMethod, Method proceed, Object[] args) throws Throwable { System.out.println("Handling " + thisMethod + " via the method handler"); return null; } }; Dog dog = (Dog) factory.create(new Class<?>[0], new Object[0], handler); dog.bark(); dog.fetch();
产生以下输出:
纬! 通过方法处理程序处理公共抽象void mock.Dog.fetch()