其实每个模式名称就表明了该模式的作用,代理模式就是多一个代理类出来,替原对象进行一些操作,比如我们在租房子的时候回去找中介,为什么呢?因为 你对该地区房屋的信息掌握的不够全面,希望找一个更熟悉的人去帮你做,此处的代理就是这个意思。再如我们有的时候打官司,我们需要请律师,因为律师在法律 方面有专长,可以替我们进行操作,表达我们的想法。先来看看关系图:
根据上文的阐述,代理模式就比较容易的理解了,我们看下代码:
- public interface Sourceable {
- public void method();
- }
- public class Source implements Sourceable {
- @Override
- public void method() {
- System.out.println(“the original method!”);
- }
- }
- public class Proxy implements Sourceable {
- private Source source;
- public Proxy(){
- super();
- this.source = new Source();
- }
- @Override
- public void method() {
- before();
- source.method();
- atfer();
- }
- private void atfer() {
- System.out.println(“after proxy!”);
- }
- private void before() {
- System.out.println(“before proxy!”);
- }
- }
测试类:
- public class ProxyTest {
- public static void main(String[] args) {
- Sourceable source = new Proxy();
- source.method();
- }
- }
输出:
before proxy!
the original method!
after proxy!
上面的讲的也是非常的清楚,就是代理类 持有 原有的对象类,用户只跟代理类打交道,不跟原有的类扯上关系,跟那个租房子特别的像,我不用联系房东,我只联系中介,我就可以租到房子
代理模式 持有 被代理对象的实例 ,这个已经理解了,这个实例一般是作为成员变量存在于代理类中的,它有个特点就是不需要你赋值,直接调用全局变量,或者构造函数里面不需要传递这个参数进去,它可以直接new的这种特性,一般都是属于代理模式
android中的具体应用:WindowManagerImpl就是一个代理类
public final class WindowManagerImpl implements WindowManager {
//
WindowManagerGlobal就是被代理的对象,
private final WindowManagerGlobal mGlobal = WindowManagerGlobal.getInstance();
private final Display mDisplay;
private final Window mParentWindow;
......
@Override
public void addView(View view, ViewGroup.LayoutParams params) {
mGlobal.addView(view, params, mDisplay, mParentWindow);
}
@Override
public void updateViewLayout(View view, ViewGroup.LayoutParams params) {
mGlobal.updateViewLayout(view, params);
}
@Override
public void removeView(View view) {
mGlobal.removeView(view, false);
}
@Override
public void removeViewImmediate(View view) {
mGlobal.removeView(view, true);
}
@Override
public Display getDefaultDisplay() {
return mDisplay;
}
}
这个例子很好的说明了代理模式的应用,其实我们实际代码中很多方法都是使用了代理模式,
它的优点就是:持有代理对象,我只关心我需要的方法,很多方法用户并不知道,没有暴露出来。