定義: 為其他對象提供一種代理以控制對這個對象的訪問。在某些情況下,一個對象不適合或者不能直接引用另一個對象,而代理對象可以在客戶端和目標對象之間起到中介的作用 角色: 1, 抽象角色:聲明真實對象和代理對象的共同介面。 2, 代理角色:代理對象角色內部含有對真實對象的引用,從而可以操作真實對象,同 ...
定義:
為其他對象提供一種代理以控制對這個對象的訪問。在某些情況下,一個對象不適合或者不能直接引用另一個對象,而代理對象可以在客戶端和目標對象之間起到中介的作用
角色:
1, 抽象角色:聲明真實對象和代理對象的共同介面。
2, 代理角色:代理對象角色內部含有對真實對象的引用,從而可以操作真實對象,同時代理對象提供與真實對象相同的介面以便在任何時刻都能代替真實對象。同時,代理對象可以在執行真實對象操作時,附加其他的操作,相當於對真實對象進行封裝。
3, 真實角色:代理角色所代表的真實對象,是我們最終要引用的對象。
分類:
靜態代理
靜態代理也就是在程式運行前就已經存在代理類的位元組碼文件,代理類和委托類的關係在運行前就確定了。
示例:
抽象角色,真實對象和代理對象共同的介面
public interface UserInfo{
public void queryUser ();
public void updateUser ();
}
真實角色
public class UserImpl implementsUserInfo{
@Override
public void queryUser() {
//查詢方法略...
}
@Override
public void updateUser() {
//修改方法略...
}
}
代理角色
public class UserProxy implementsUserInfo{
private UserInfo userImpl;
public AccountProxy(UserInfo userImpl) {
this.userImpl = userImpl;
}
@Override
public void queryUser() {
//這裡可以擴展,增加一些查詢之前需要執行的方法
//查詢方法略...
//這裡可以擴展,增加一些查詢之後需要執行的方法
}
@Override
public void updateUser() {
//這裡可以擴展,增加一些修改之前需要執行的方法
//修改方法略...
//這裡可以擴展,增加一些修改之後需要執行的方法
}
}
使用代理之後如何調用他的方法?
public class Test {
public static void main(String[] args) {
UserInfo userImpl = new UserImpl();
UserInfo userProxy = new UserProxy(userImpl);
userProxy.queryUser();
userProxy.updateUser();
}
}
動態代理
動態代理類的源碼是程式在運行期間由JVM根據反射等機制動態生成的,所以不存在代理類的位元組碼文件。代理角色和真實角色的聯繫在程式運行時確定。
示例:
抽象角色,真實對象和代理對象共同的介面
public interface UserInfo{
public void queryUser ();
public void updateUser ();
}
真實角色
public class UserImpl implementsUserInfo{
@Override
public void queryUser() {
//查詢方法略...
}
@Override
public void updateUser() {
//修改方法略...
}
}
代理角色處理器:
public class UserHandler implementsInvocationHandler{
privateUserInfo userImpl;
publicUserHandler(UserInfo userImpl2){
this.userImpl= userImpl2;
}
@Override
publicObject invoke(Object proxy, Method method, Object[] args)
throws Throwable {
Objectobject = null;
//方法開始前做一些事情
if (method.getName().equals("queryUser")) {
object = method.invoke(userImpl, args);
//激活調用的方法
}
//方法結束後做一些事情
return object;
}
}
如何調用(和靜態代理略有不同)
public class Test {
public static void main(String[] args) {
UserInfouserImpl =new UserImpl();
UserHandlerhandler = new UserHandler(userImpl);
UserInfouserProxy = (UserInfo)Proxy.newProxyInstance
(ClassLoader.getSystemClassLoader(),
newClass[]{UserInfo.class}, handler);
userProxy.queryUser();
}
}
優點:
業務類只需要關註業務邏輯本身,保證了業務類的重用性。這是代理的共有優點。
能夠協調調用者和被調用者,在一定程度上降低了系統的耦合度。
缺點:
由於在客戶端和真實主題之間增加了代理對象,因此有些類型的代理模式可能會造成請求的處理速度變慢,例如保護代理。
實現代理模式需要額外的工作,而且有些代理模式的實現過程較為複雜,例如遠程代理。