美文网首页
装饰者模式

装饰者模式

作者: 1dot4 | 来源:发表于2019-02-02 14:44 被阅读16次

    介绍

    装饰者模式,结构型设计模式之一,其使用一种对客户端透明的方式来动态的扩展对象的功能,同时它也是继承关系的一种替代方式。,且更为灵活。

    类图

    UML类图

    Android源码中的模式实现

    Context类在Android中被称作“上帝对象”,它本质上是一个抽象类,其在我们装饰者模式中就相当于抽象组件,而在内部定义了大量的抽象方法,比如startActivity方法。

    public abstract class Context {
        public abstract void startActivity(Intent var1);
    }
    

    真正的实现是在ContextImpl中完成的,ContextImpl继承Context类,并实现了Context中的抽象方法:

    public final class ContextImpl extends Context {
    
      @Override
      public void startActivity(Intent intent){
         warnIfCallFromSystemProcess();
         startActivity(intent,null);
      }
    
    }
    

    这里的ContextImpl相当于组件的具体实现类,那么谁来充当装饰者的身份呢?我们知道Activity从层次上来说本质上是个Context,但是留意过其代码的会发现Activity并非继承Context,而是继承ContextThemeWrapper.

    public class Activity extends ContextThemeWrapper
            implements LayoutInflater.Factory2,
            Window.Callback, KeyEvent.Callback,
            OnCreateContextMenuListener, ComponentCallbacks2,
            Window.OnWindowDismissedCallback, WindowControllerCallback,
            AutofillManager.AutofillClient {
            //...
    }
    

    而这个ContextThemeWrapper又是继承ContextWrapper:

    public class ContextWrapper extends Context {
        Context mBase;
    
        public ContextWrapper(Context base) {
            mBase = base;
        }
    
         @Override
        public void startActivity(Intent intent) {
            mBase.startActivity(intent);
        }
    
    }
    

    最终这个ContextWrapper继承Context。可看到这个就是一个典型的装饰者模式,ContextWrapper就是我们要找的装饰者,在ContextWrapper中有一个Context的引用。ContextWrapper中所有的方法都是简单调用了具体组件实现类ContextImpl中对应的方法而已。

    总结

    装饰模式和之前学习的代理模式有点类似。装饰模式是对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案;而代理模式是给对象提供一个的代理对象,并由代理对象来控制对原有对象的引用。装饰模式应该为所装饰的对象增强功能;代理模式对代理的对象施加控制,但不对对象本身的功能进行增强。

    相关文章

      网友评论

          本文标题:装饰者模式

          本文链接:https://www.haomeiwen.com/subject/ifrssqtx.html