简介
java.lang.reflect 包下提供了一个Proxy 类和 InvocationHandler 接口,通过这个类和接口可以生成JDK 动态代理类或动态代理对象。
创建动态代理类
Proxy 类提供了静态方法生成静态代理类或静态代理对象,Proxy 也是所有动态代理类的父类。
1.Class<?> getProxyClass(ClassLoader loader,Class<?>… interfaces) : 创建动态代理类,loader 指生成动态代理类的类加载器,interfaces 指该代理类实现的一个或多个接口
2.Object newProxyInstance(ClassLoader loader,Class<?>[] interfaces,InvocationHandler h) : 创建动态代理对象,该代理对象实现系列接口,执行代理对象的每个方法都将被替换执行InvocationHandler 对象的invoke 方法。
使用方式getProxyClass 生成的动态代理类在创建对象时也也要在构造器中传入InvocationHandler 对象。
com.sxt.test.Test.java 实现如下:
package com.sxt.test;
import java.lang.reflect.*;
public class Test {
static interface Testable {
void test1();
void test2(String args);
}
public static void main(String[] args) throws ClassNotFoundException, NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException {
Testable t = (Testable) Proxy.newProxyInstance(Testable.class.getClassLoader(), new Class[] {Testable.class}, new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println(proxy.getClass());
System.out.println(proxy.getClass().getSuperclass());
System.out.println(method);
System.out.println(args);
return null;
}
});
t.test1();
t.test2("你好");
}
}
运行效果如下:
总结
如果实现InvocationHandler 接口的对象内部封装了被代理对象,则在InvocationHandler 的 invoke 方法中调用被代理对象的方法即可实现高级框架解耦的目的。