简介

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("你好");
	}
}

运行效果如下:
反射生成JDK 动态代理

总结

如果实现InvocationHandler 接口的对象内部封装了被代理对象,则在InvocationHandler 的 invoke 方法中调用被代理对象的方法即可实现高级框架解耦的目的。

相关文章: