在项目运行的时候才创建一个代理对象,对方法进行增强(控制)
方式1:
jdk中Proxy类,前提:实现接口
方式2:
spring中cglib,前提:继承类
动态的在内存中创建一个代理对象
Object Proxy.newProxyInstance(ClassLoader loader, Class[] interfaces, InvocationHandler h)
参数说明:
ClassLoader:代理对象类加载器 一般我们使用的是被代理对象的类加载器
Class[]:代理对象需要实现接口 一般我们使用的是被搭理对象所实现的所有接口
InvocationHandler:执行处理类.在这里面对方法进行加强
invocationHandler中只有一个方法:
Object invoke(Object proxy, Method method, Object[] args)
参数说明:
proxy:代理对象
method:当前执行的方法
args:当前方法执行的时候所需要的参数
返回值:就是当前method对象执行的返回值
例子:QQ类继承Car接口,实现了run方法和stop方法
public class TT {
public static void main(String[] args) {
final QQ qq=new QQ();
//创建代理对象
Car qqProxy=(Car) Proxy.newProxyInstance(QQ.class.getClassLoader(), new Class[]{Car.class}, new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
if("run".equals(method.getName())){
System.out.println("加上电池");
//这里的obj表示方法的返回值,method.invoke执行一次就代表原来的方法执行了一次
Object obj = method.invoke(qq, args);
System.out.println("5秒破百");
//这里的obj表示方法的返回值,汽车的run方法是打印输出语句,没有返回值,所以obj相当于null。
return obj;
}
//method.invoke执行一次就代表原来的方法执行了一次,并且通过return把这个方法的返回值返回。
return method.invoke(qq, args);
}
});
qqProxy.run();
qqProxy.stop();
}
}
网友评论