------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------
JDK动态代理:
为何叫JDK动态代理呢?
所谓JDK,jdk是java开发工具包,它里面包含了一个动态代理的api
代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问。代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理。
何为动态?相比于静态代理,动态代理避免了开发人员编写各个繁锁的静态代理类,只需简单地指定一组接口及目标类对象就能动态的获得代理对象。
下面我拿例子带入,具体的动态代理案例如下:
首先按平时的方式来写,一个接口,一个实现它的类
ISomeService接口
package cn.dawn.day09jdkdtproxy;
/**
* Created by Dawn on 2018/3/8.
*/
public interface ISomeService {
public void doSome();
}
SomeServiceImpl类,实现ISomeService接口
package cn.dawn.day09jdkdtproxy;
/**
* Created by Dawn on 2018/3/8.
*/
public class SomeServiceImpl implements ISomeService {
public void doSome() {
System.out.println("do something");
}
}
测试类,用动态代理的形式,对方法进行增强操作
package cn.dawn.day09jdkdtproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
/**
* Created by Dawn on 2018/3/8.
*/
public class Test {
public static void main(String[] args) {
/*匿名内部类要想得到外面的值,需要把外面的值改为常量*/
final ISomeService service=new SomeServiceImpl();
/*用动态代理的方式生成ISomeService的对象,就是增强后的对象,可以看看newProxyInstance的方法参数,就有方法去写了*/
/*InvocationHandler是由代理实例的调用处理程序实现的接口。*/
ISomeService proxy=(ISomeService)Proxy.newProxyInstance(service.getClass().getClassLoader(), service.getClass().getInterfaces(), new InvocationHandler() {
/**
*invoke:每个代理实例都有一个关联的调用处理程序。当在代理实例上调用方法时,方法调用将被编码并分派给invoke 其调用处理程序的方法。
* @param proxy 代理对象,没啥用
* @param method 反射获取的方法
* @param args 方法的参数
* @return
* @throws Throwable
*/
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println("before===================");
method.invoke(service,args);//相当于执行目标类型的方法
return null;
}
});
proxy.doSome();
}
}
值得一提的是:Proxy是java.lang.reflect包下,正因如此,才叫JDK动态代理