设计模式 |09 外观模式

本贴最后更新于 1919 天前,其中的信息可能已经时移俗易

开头说几句

博主的博客地址: https://www.jeffcc.top/
博主学习设计模式用的书是 Head First 的《设计模式》,强烈推荐配套使用!

什么是外观模式

权威定义:外观模式提供了一个统一的接口,用来访问子系统中的一群接口,外观模式定义了一个高层接口,让子系统更容易被使用。
博主的理解:外观模式的目的是为了简化系统中的复杂的接口的调用,比如我们要回家,那么每次都需要自己开锁、开灯、开风扇甚至打开电视等的操作,而这些操作要一步步自己实现的话就太累了,所以我们可以通过外观模式来设计一个一键回家启动设备的外观,我们只需要调用外观接口就能够做到这一系列复杂的操作了!

外观模式与适配器模式

外观模式:

  1. 目的是通过外观来调用一个大系统中的很多功能那个;使用的是组合,类的耦合度比较低。
  2. 一个系统中可以有许多的外观,增加了系统的可拓展性。

适配器模式:

  1. 目的是通过继承来把一个不需要的类伪装成需要的类,使用的是继承,耦合度相对而言比较高。

外观模式与命令模式

外观模式:通过组合的方法,组合的是一个大接口,接口中会有许多的实现;
命令模式:也是通过组合的方法,但是组合的是一个一个一个的具体的接口的实现方法;与命令模式的宏命令有点相似,但是组成不同;

设计原则

最少知识原则:简而言之就是只和你的“密友”谈话,在真实的设计中,则是需要避免出现很多类耦合在一起,以免造成以后修改系统的时候影响到其他部分的正常运行。我的理解就是在类中出现的对象越少越好,当然这是在能完成类的任务的前提下;

设计实例

设计一个家庭一键启动系统

项目类图

image.png

项目结构

image.png

风扇控制器

空调控制器

灯光控制器

电视控制器

回家一键启动外观

离家一键启动外观
测试
测试结果
back home!!!!
All light is on!!!!
TV is on!!!!
AirConditioner is on!!!!
Fan is on Low!!!!
------------------------------------
leave home!!!
All light is off!!!!
TV is off!!!!
AirConditioner is off!!!!
Fan is Off!!!!

回到定义

我们说的外观模式就是在诸多接口上定义再定义一个访问这些子接口的大接口,而在这个实例中就体现的淋漓尽致了,子接口群对应着这些单独的家具控制器,而大接口则是对应着我们的回家一键模式以及离家一键模式,这些就对应着我们的外观了,给子接口套上一层外观,方便了客户的调用。
同时这也是最少知识原则的体现,我们的外观与用户层只有一个接口的耦合,如果不使用外观模式的话,就会需要用户自己手动一个一个的调用我们的子接口,这样在用户层这一块就会导致直接与过多的类进行了耦合,违背了最少知识原则!


END
2019 年 9 月 21 日 09:48:36

  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...