神评列表

  • 神评
    追求的艺术
    2
    2020-09-15 20:06:34
    有东西

深度: 优秀程序员必会的设计模式之——外观模式,有东西,基本介绍外观模式也叫做“过程模式”,该模式的...

2020-09-15 07:30:00
1

神回复:有东西

基本介绍

外观模式也叫做“过程模式”,该模式的核心思想是为不同子系统(类)中的一组接口提供一个一致的界面(类)。也就是定义一个高层次的类,该类封装了一些低层次的类和其方法,客户端使用时就用该类。

通过外观模式可以屏蔽子系统中的细节,促使调用端只需要跟高层次的类发生关系即可,无需再关注子系统的内部实现细节。

外观模式还从一定程度上简化了用户的操作,降低了使用的复杂度。

外观模式UML类图

深度: 优秀程序员必会的设计模式之——外观模式图1

角色以及职责讲解:

1、FacadeClass(外观类):给客户端提供统一的接口,外观类知道当前的请求由哪些子系统负责。从而可以做到将客户端的请求代理给适当的子系统进行处理。

2、Subsystem1-4(子系统):功能的实际提供者,用于处理外观类指派来的任务。

3、Client(客户端):外观类的调用者。

案例讲解

通过以上的类图和描述大家是否对外观模式有了一定的认识?下面让我们通过一个小案例来体会一下外观模式的魅力。

案例:到吃饭的时间了小菜鸟想吃西红柿鸡蛋面,现在有两个选择,可以选择自己买好原材料,自己做饭,也可以选择下馆子(饭店)。作为一个聪明的菜鸟,我当然是选择下馆子嘛,有现成的为什么要自己造轮子那?这里的饭店就相当外观类,下面让我们用代码实现以下。

子系统相关类

深度: 优秀程序员必会的设计模式之——外观模式图2
深度: 优秀程序员必会的设计模式之——外观模式图3深度: 优秀程序员必会的设计模式之——外观模式图4

外观类

深度: 优秀程序员必会的设计模式之——外观模式图5

客户端测试类

深度: 优秀程序员必会的设计模式之——外观模式图6

测试结果

深度: 优秀程序员必会的设计模式之——外观模式图7

总结

1、外观模式对外屏蔽了子系统的实现细节,从而降低了客户端对子系统使用的复杂度。

2、使用外观模式可以降低客户端与子系统的耦合性,使得子系统内部更容易维护和扩展。

3、当系统需要分层设计时,可以使用外观模式,并且通过合理的使用外观模式,可以帮我们更好的划分系统的访问层次。

4、不能过多的或者不合理的使用外观模式。具体是使用外观模式好,还是直接调用模块好,要以让系统有层次,利于维护为目的。

今天的分享就到这里了,如果感觉“菜鸟”写的文章还不错,记得点赞加关注呦!你们的支持就是我坚持下去的动力。文章哪里写的有问题的也希望大家可以指出,我会虚心受教。

深度: 优秀程序员必会的设计模式之——外观模式图8
17457
1
1397
可匿名神评,需审核
匿名神评

最新评论

  • 追求的艺术
    2
    2020-09-15 20:06:34

    有东西

猜你喜欢

最新资讯