前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >设计模式(二)之装饰模式 | 说好了面向对象,谁也不许赖谁~

设计模式(二)之装饰模式 | 说好了面向对象,谁也不许赖谁~

作者头像
谭庆波
发布2018-08-10 11:02:08
1390
发布2018-08-10 11:02:08
举报
文章被收录于专栏:轮子工厂

装饰模式之前的面向对象原则介绍

单一职责原则:就一个类而言,应该仅有一个引起它变化的原因。也就是说功能要单一。

  1. 优点: 灵活性,可复用性。
  2. 如果一个类承担的职责太多,就等于把这些职责耦合在一起,一个职责的变化可能会削弱或者阻碍其他职责能力,这种耦合会导致脆弱的设计,当变化发生时,设计会发生意想不到的变化。

开放封闭原则:软件应该可以扩展,但不可以修改。对于扩展是开放的,对于更改是封闭的。

  1. 面对需求,对程序的改动是通过增加新代码进行的,而不是更改现有代码,这就是开放封闭原则的精神所在。
  2. 优点:可扩展 可复用 灵活性好。

依赖倒转原则:抽象不应该依赖细节,细节不应该依赖抽象。针对对接口编程,不要对实现编程。即高层模块不依赖底层模块,底层模块不依赖高层模块。

  1. 其实就是谁也不依赖谁,除了约定的接口,大家都可以灵活自如。

里氏代换原则:子类型必须能够替换掉他们的父类型,只有当子类可以替换掉父类,软件单位功能不受影响时,父类才能真正被复用。

装饰模式

定义:动态地给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活。

装饰模式是为已有功能动态的添加更多功能的一种方式。

代码实现:

代码语言:javascript
复制
//需要被装饰的对象public class Person {
    private String name;
    public Person(String name) {        super();        this.name = name;    }
    public Person() {        super();    }
    public void show(){
        System.out.println("装扮的"+name);    }
}
//功能的抽象类
public class Finery extends Person{
    protected Person component;    //打扮    public void Decorate(Person component){        this.component = component;    }    @Override    public void show(){        if(component != null){            component.show();        }    }
}//继承功能类public class BigTrouser extends Finery {    @Override
    public void show(){        System.out.println("垮裤");        super.show();    }
}
//继承功能类
public class TShirts extends Finery {
    @Override
    public void show(){        System.out.println("大T恤");        super.show();    }
}//继承功能类public class WearSneakers extends Finery {    @Override    public void show(){        System.out.println("破球鞋");        super.show();
    }
}
//继承功能类public class WearSuit extends Finery{    @Override    public void show(){        System.out.println("西装");        super.show();    }}
//动态给对象添加功能
public class Test {    public static void main(String[] args) {
        Person xc = new Person("小菜");
        System.out.println("第一种装扮:");
        WearSneakers w = new WearSneakers();
        WearSuit ws = new WearSuit();
        BigTrouser bt = new BigTrouser();
        /*
         * 首先实例化person对象
         * 再用WearSneakers类包装person
         * 再用WearSuit类来包装WearSneakers对象         * 再用BigTrouser类包装WearSuit对象         * 最终执行BigTrouser的show方法。         * 
         */
        w.Decorate(xc);   
        ws.Decorate(w);
        bt.Decorate(ws);
        bt.show();
    }
}

输出结果:

第一种装扮: 垮裤 西装 破球鞋 装扮的小菜

什么时候使用装饰模式

  • 当系统需要新功能时,是向旧的类中添加新的代码,这些新代码通常装饰了原有的核心职责或主要行为。
  • 把每个要装饰的功能放在单独的类中,并让这个类包装它所有装饰的对象。

优点:

  • 把类的核心职责和装饰功能区分开来,去除相关类中重复的装饰逻辑。
  • 简化原有类。

为你推荐以下文章

设计模式(一) | 啥是工厂模式和策略模式?

务实基础篇--Java内存模型及GC原理

深入理解Java中的List、Set与Map集合

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-04-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 轮子工厂 微信公众号,前往查看

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

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

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