python : 设计模式之外观模式(Facade Pattern)

#为啥要用外观模式举例说明

这个例子很形象,直接从人家博客上贴过来的,参考链接在下面

不知道大家有没有比较过自己泡茶和去茶馆喝茶的区别,如果是自己泡茶需要自行准备茶叶、茶具和开水,如图1(A)所示,而去茶馆喝茶,最简单的方式就是跟茶馆服务员说想要一杯什么样的茶,是铁观音、碧螺春还是西湖龙井?正因为茶馆有服务员,顾客无须直接和茶叶、茶具、开水等交互,整个泡茶过程由服务员来完成,顾客只需与服务员交互即可,整个过程非常简单省事,如图1(B)所示。

 

 

在软件开发中,有时候为了完成一项较为复杂的功能,一个客户类需要和多个业务类交互,而这些需要交互的业务类经常会作为一个整体出现,由于涉及到的类比较多,导致使用时代码较为复杂,此时,特别需要一个类似服务员一样的角色,由它来负责和多个业务类进行交互,而客户类只需与该类交互。外观模式通过引入一个新的外观类(Facade)来实现该功能,外观类充当了软件系统中的“服务员”,它为多个业务类的调用提供了一个统一的入口,简化了类与类之间的交互。在外观模式中,那些需要交互的业务类被称为子系统(Subsystem)。如果没有外观类,那么每个客户类需要和多个子系统之间进行复杂的交互,系统的耦合度将很大;而引入外观类之后,客户类只需要直接与外观类交互,客户类与子系统之间原有的复杂引用关系由外观类来实现,从而降低了系统的耦合度。

 

 

#定义

外观模式为系统中的一组接口提供一个一致的界面,定义一个高层接口,这个接口使得子系统更加容易使用。

 

 

 #看图理解外观模式

 

 

 #涉及角色

1).门面角色:外观模式的核心。它被客户角色调用,它熟悉子系统的功能。内部根据客户角色的需求预定了几种功能的组合。
2).子系统角色:实现了子系统的功能。它对客户角色和Facade时未知的。它内部可以有系统内的相互交互,也可以由供外界调用的接口。
3).客户角色:通过调用Facede来完成要实现的功能。

 

 

#使用场景

比如经典的MVC三层架构

 

#优点

1.减少系统相互依赖,降低耦合, 为复杂的模块或子系统提供外界访问的模块

2.提高灵活性,子系统相对独立

3.提高安全性,预防低水平人员带来的风险

 

 #经典代码结构

class SubSystemA:
    def methodA(self):
        pass
class SubSystemB:
    def methodB(self):
        pass
class SubSystemC:
    def methodC(self):
        pass

class Facade:
    objA=None
    objB=None
    objC=None

    def __init__(self):
        self.objA=SubSystemA()
        self.objB=SubSystemB()
        self.objC=SubSystemC()

    def method(self):
        self.objA.methodA()
        self.objB.methodB()
        self.objC.methodC()

def clientUI():
    facade=Facade()
    facade.method()

if __name__=='__main__':
    clientUI()

 

 

 

参考

https://www.cnblogs.com/adamjwh/p/9048594.html

https://www.2cto.com/kf/201803/726607.html

https://blog.csdn.net/LoveLion/article/details/8258121

https://blog.csdn.net/ponder008/article/details/6868815

 

posted @ 2019-08-05 09:39  筱筱的春天  阅读(597)  评论(0编辑  收藏  举报