/* 代理模式
*
* 生活中:
* (1)本身不方便作一些事情,例如:去国外 找代购 租房 买房 等等...
* 一、代理模式
* (1)主题接口:要求代理类与被代理类实现同一个接口,例如:DAO接口
* (2)被代理者
* (3)代理者
* 必须持有被代理者的引用
*
* 二、静态代理模式
* 缺点:一个代理类只能替一个代理主题(接口)代理工做
*
* 三、动态代理模式
* 优势:一个代理工做处理器,能够替多个代理主题代理工做,只有代理工做内容同样就能够。
* 须要:
* (1)编写一个代理工做处理器的类,这个类必须实现一个接口InvocationHandler
* (2)用JDK中提供了一个Proxy类,来建立代理类的对象
* (3)调用方法ide
示例: 静态代理this
interface A{
void run();
}代理
class B implements A{
@Override
public void run() {
for (int i = 0; i < 1000; i++) {
System.out.println(i);
}
}
}对象
class StaticProxy implements A{
private A a;
public StaticProxy(A a) {
this.a = a;
}接口
@Override
public void run() {
System.out.println("run方法执行");
long start = System.currentTimeMillis();
a.run();
long end = System.currentTimeMillis();
System.out.println("执行时间:" + (end - start));
System.out.println("run方法执行结束");
}
}get
静态代理的使用:new StaticProxy(new B()).run()io
示例:动态代理class
interface C {
void run();
}object
class CImpl implements C{
@Override
public void run() {
System.out.println("C接口的run方法执行中");
}
}引用
class DynamicProxy implements InvocationHandler {
//被代理的对象
private Object obj;
public DynamicProxy(Object obj){
this.obj = obj;
}
/*
* 参数一:代理类的对象
* 参数二:被代理者要执行的方法
* 参数三:被代理者要执行的方法须要的实参列表
* 这个方法不是程序调用的,是一会执行代理类对象的方法时自动调用
*/
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println(method.getName() + "方法执行");
long start = System.currentTimeMillis();
Object object = method.invoke(obj, args);
long end = System.currentTimeMillis();
System.out.println("执行时间:" + (end - start));
System.out.println(method.getName() + "方法执行结束");
return object ;
}
}
动态代理使用:
public class TestProxy2 {
public static void main(String[] args) {
Class clazz = CImpl.class;
ClassLoader loader = clazz.getClassLoader();
Class[] interfaces = clazz.getInterfaces();
C proxy = (C) Proxy.newProxyInstance(loader, interfaces, new DynamicProxy(clazz));
proxy.run();
}
}