【技術累積】【點】【java】【30】代理模式
阿新 • • 發佈:2018-10-31
基礎
代理模式是Java常見的設計模式之一。所謂代理模式是指客戶端並不直接呼叫實際的物件,而是通過呼叫代理,來間接的呼叫實際的物件。
什麼是代理
參考現實生活中的代理
比如某個品牌的某個省的代理商,作為客戶我們只會跟省代理這邊買東西,而不會直接跟廠商接觸。這裡的代理,是商家代理了品牌。
所謂正向代理和反向代理,就要理解正向和反向。
這裡的方向,個人理解是呼叫發生的方向。
正向代理:
- 是伺服器代理使用者;
- 多個使用者使用代理伺服器,代理伺服器呼叫唯一服務端伺服器;
- 隱藏了真實的請求客戶端;
反向代理:
- 是伺服器代理服務端伺服器;
- 一個使用者呼叫代理伺服器,代理伺服器呼叫多個服務端伺服器;
隱藏了真實的服務端;
程式中的代理模式
通過聚合/注入的模式,拆分呼叫,分為靜態代理和動態代理。
- 代理類和實際類都實現了抽象的Subject介面,保證了對客戶端的使用透明;
- 在代理類中統一呼叫實現的方法,呼叫者為注入的某個實際類,具體為客戶端選擇;
- 在實際類中定義個性化實現;
靜態代理
程式碼體現
public interface Subject { void visit(); } public class RealSubject implements Subject { private String name = "byhieg"; @Override public void visit() { System.out.println(name); } } public class ProxySubject implements Subject{ private Subject subject; public ProxySubject(Subject subject) { this.subject = subject; } @Override public void visit() { subject.visit(); } } public class Client { public static void main(String[] args) { ProxySubject subject = new ProxySubject(new RealSubject()); subject.visit(); } }
動態代理
動態代理和靜態代理的不同,主要體現在
- 客戶端呼叫
- 代理類的實現
其中代理類的實現是關鍵,即從直接寫死到動態生成;
動態生成,一方面需要寫動態代理的宣告,然後例項化
public class DynamicProxy implements InvocationHandler { private Object object; public DynamicProxy(Object object) { this.object = object; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { Object result = method.invoke(object, args); return result; } } Subject realSubject = new RealSubject(); DynamicProxy proxy = new DynamicProxy(realSubject); ClassLoader classLoader = realSubject.getClass().getClassLoader(); Subject subject = (Subject) Proxy.newProxyInstance(classLoader, new Class[]{Subject.class}, proxy); subject.visit();