反射生成JDK 动态代理

简介

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 方法中调用被代理对象的方法即可实现高级框架解耦的目的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值