您好,登錄后才能下訂單哦!
最近再看書時,書中使用了java的動態代理機制,隨即在網上搜了些文章看了一下,既然有動態代理那就有靜態代理,所謂靜態代理,就是在你些的代理類中需要使用到具體的被代理類。而所謂動態代理,則不需要在代理類中使用到被代理類,根本不知道起要代理那個類。在jdk1.3后java加入了動態代理功能的api,動態代理主要用在面向接口編程上,業務邏輯的實現類必須實現某業務接口,通過使用動態代理, 我們可以在代理類中攔截器功能。java的動態代理功能是通過實現java.lang.reflect.InvocationHandler接口來實現的。實現類必須實現接口中定義的invoke方法。下面是一段實現動態代理的代碼。
package com.spring;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.logging.*;
/**
* 此類用于實現動態代理
* @author paul
*
*/
public class LogHandler implements InvocationHandler {
private Logger logger = Logger.getLogger(this.getClass().getName());
private Object delegate;
//綁定被代理對象,返回被代理對象所實現的接口
public Object bind(Object delegate) {
this.delegate = delegate;
return Proxy.newProxyInstance(delegate.getClass().getClassLoader(),
delegate.getClass().getInterfaces(), this);
}
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
Object result = null;
try {
log("method1" + method);
result = method.invoke(delegate, args);
logger.log(Level.INFO, "method ends" + method);
} catch (Exception e) {
log(e.toString());
}
return result;
}
private void log(String message) {
logger.log(Level.INFO, message);
}
}
一下是定義業務邏輯方法的
package com.spring;
public interface IHello {
public void hello(String name);
}
一下是接口實現類,即業務邏輯實現類
package com.spring;
/**
* 此類用于實現業務邏輯
* @author Administrator
*
*/
public class HelloSpeaker implements IHello {
/**
* 實現接口方法
* @return void
*/
public void hello(String name) {
System.out.println("Hello," + name);
}
}
一下是用于測試的類
package com.spring;
public class ProxyDemo {
/**
* @param args
*/
public static void main(String[] args) {
// HelloProxy proxy=new HelloProxy(new HelloSpeaker());
// proxy.hello("paul");
LogHandler loghandler = new LogHandler();
IHello helloProxy = (IHello) loghandler.bind(new HelloSpeaker());// 綁定代理對象
helloProxy.hello("paul");// 該句執行時會調用invoke方法
}
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。