静态代理示图
代理对象里面是没有实际的方法的,执行方法是调用目标对象的方法,其中可以对目标方法进行增强。
动态代理:
动态代理的代理对象不需要实际创建,当要使用的时候,才会在内存动态生产代理对象执行目标的方法。
演示1:
演示2:
代理对象,在内存动态生成,传入接口数组时候,决定返回代理对象的类型。调用的方法,实际是通过传入目标对象,再调用目标对象方法。
目标对象:
package com.itheima.proxy;
public class Target implements TargetInterface{
@Override
public void method1() {
System.out.println("method1 running...");
}
@Override
public String method2() {
System.out.println("method2 running...");
return "method2";
}
@Override
public int method3(int x) {
return x;
}
}
共同实现的接口:
package com.itheima.proxy;
public interface TargetInterface {
public void method1();
public String method2();
public int method3(int x);
}
动态代理:
package com.itheima.proxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class ProxyTest2 {
public static void main(String[] args) {
final Target target = new Target();
//动态创建代理对象
TargetInterface proxy = (TargetInterface) Proxy.newProxyInstance(
target.getClass().getClassLoader(),
target.getClass().getInterfaces(),
new InvocationHandler() {
@Override
//被执行几次?------- 看代理对象调用方法几次
//代理对象调用接口相应方法 都是调用invoke
/*
* proxy:是代理对象:不要轻易调用,造成死循环
* method:代表的是目标方法的字节码对象
* args:代表是调用目标方法时参数
*/
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//反射知识点
Object invoke = method.invoke(target, args);//目标对象的相应方法
//retrun返回的值给代理对象
return invoke;
}
}
);
proxy.method1();//调用invoke---Method:目标对象的method1方法 args:null 返回值null
String method2 = proxy.method2();//调用invoke---Method:目标对象的method2方法 args:null 返回值method2
int method3 = proxy.method3(100);调用invoke-----Method:目标对象的method3方法 args:Object[]{100} 返回值100
System.out.println(method2);
System.out.println(method3);
}
}