前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android设计模式应用-装饰器模式

Android设计模式应用-装饰器模式

作者头像
wust小吴
发布2019-07-08 17:57:21
6750
发布2019-07-08 17:57:21
举报
文章被收录于专栏:风吹杨柳风吹杨柳

给一个对象动态的添加方法,就是装饰器模式,通常的做法就是将   原始对象作为一个参数传递给  装饰者构造器

它的目的:是扩展,不是访问

设计模式原则中,就有对扩展开放,对修改关闭

  1. public interface Sourceable {  
  2.     public void method();  
  3. }  
  4. public class Source implements Sourceable {  
  5.     @Override  
  6.     public void method() {  
  7.         System.out.println(“the original method!”);  
  8.     }  
  9. }  
  10. public class Decorator implements Sourceable {  
  11.     private Sourceable source;  
  12.     public Decorator(Sourceable source){  
  13.         super();  
  14.         this.source = source;  
  15.     }  
  16.     @Override  
  17.     public void method() {  
  18.         System.out.println(“before decorator!”);  
  19.         source.method();  
  20.         System.out.println(“after decorator!”);  
  21.     }  

这是网上那个说明设计模式中的关于装饰模式的代码结构,android中的代码又是怎么弄的呢?

 public class ContextWrapper extends Context {

    Context mBase;

    public ContextWrapper(Context base) {

        mBase = base;

    }

    @Override

    public Object getSystemService(String name) {

        return mBase.getSystemService(name);   

    }

//这种形式不知道大家遇到过没有,比如我们适配器构造的时候,是不是也传递了一个context啊,我们似乎还传递了一个数据集对象呢,但是这只能说明是形式上一样,但是真正实现了定义中的功能了吗,对扩展开放,有没有动态的添加一个方法呢,我们还不知道哦,接着看,这里面有一个getSystemService方法,我们去看看他是怎么做的,需要在子类中进行重载

    @Override 

    public Object getSystemService(String name) {

        //下面的代码就是对这个方法的扩展    

        if (LAYOUT_INFLATER_SERVICE.equals(name)) {

            if (mInflater == null) { 

               mInflater = LayoutInflater.from(getBaseContext()).cloneInContext(this);//原型模式的应用

            }

            return mInflater;

        }

        return getBaseContext().getSystemService(name);

    } 

这里面看起来似乎还是有点难懂对吧,还没有java那段代码来的直接,在java代码中在method方法前面和后面加了两句代码,那个过程也是对method方法的一种扩展,这个里面也是在子类中对这个方法进行了扩展,

如果我们从另外一个方面去理解就是,这个方法被我重写了,就是完成扩展了,但是装饰器模式还有个特点就是:原有对象必须是通过构造函数传递进来的参数,如果满足这两点,就算是扩展了,

至于扩展到底做了什么处理,我们并不关心这个。

装饰器模式和  代理模式  其实很相近,都是在一个类中有原有对象的实例,代理模式不需要传参进来,装饰器模式必须要传递参数进来说明是哪个原有对象上进行装饰(扩展功能),代理模式是对原有对象进行访问,装饰器模式是对原有对象的方法进行重载扩展,这个方法可以在当前的装饰器类中重载,也可以在装饰器子类中进行重载,都是允许的。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年04月03日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档