1.靜態代理機制的缺點
在靜態代理中,因爲一個靜態代理類只能爲一個接口服務,如果有很多的接口,那麼就會產生很多的代理類。而且所有的代理除了調用方法不一樣以外
其他的代碼都是相同的,這樣就會出現大量重複的代碼
2.動態代理的實現
InvocatiionHandler接口
public interface InvocationHandler
Object invoke(Object proxy, Method method, Object[] args)
可以將InvocationHandler 想像成一個代理的最終操作類,替換到ProxySubject
Proxy類方法:
static Object |
newProxyInstance(ClassLoader loader,
Class<?>[] interfaces,
InvocationHandler h) 返回一個指定接口的代理類實例,該接口可以將方法調用指派到指定的調用處理程序。 |
具體實現
package com.qunar.dynaproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
interface Subject{
public String say(String name,int age);
}
class RealSubject implements Subject{
public String say(String name,int age){
return "name:"+name+",age:"+age;
}
}
class myInvocationHandler implements InvocationHandler{
private Object object;//真實主題
public Object bind(Object object){
this.object = object;
return Proxy.newProxyInstance(object.getClass().getClassLoader(), object.getClass().getInterfaces(), this);
}
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
this.before();//就相 當於Spring AOP
Object temp = method.invoke(object, args);
return temp;
}
private void before(){
System.out.println("代理操作之前");
}
}
public class DynaProxyDemo {
public static void main(String[] args) {
Subject sub = (Subject) new myInvocationHandler().bind(new RealSubject());
String content = sub.say("suhao", 23);
System.out.println(content);
}
}
使用動態代理就可以完成代理的功能,而且可以代理全部的接口