官术网_书友最值得收藏!

Knowing when to use the Facade Pattern

Suppose you are designing a system, and this system has a very large number of independent classes and also has a set of services to be implemented. This system is going to be very complex, so the Facade pattern comes into the picture and reduces the complexities of the larger system and simplifies interactions of the client code with a set of classes from a subsystem of the large complex system.

Suppose you want to develop a bank enterprise application with a large number of services to perform a task, for example, AccountService for getting the Account by accountId, PaymentService for payment gateway services, and TransferService for the amount transfer from one account to another account. A client code of the application interacts with all these services to transfer money from one account to another account. This is how different clients interact with the amount transfer process of the bank system. As shown in the following figure, here you can see client code that directly interacts with the subsystem classes and client also should aware about the internal working of subsystem classes, so it is simply a violation of the SOLID design principles because client code is tightly coupled with the classes of subsystem of your banking application:

Banking Application Subsystem without Facade Design Pattern

Rather than client code directly interacting with the classes of a subsystem, you could introduce one more interface, which makes the subsystems easier to use, as shown in the following figure. This interface is known as a Facade interface, it is based on the Facade pattern, and it is a simple way to interact with the subsystems:

Banking Application Subsystem with Facade design pattern
主站蜘蛛池模板: 华蓥市| 中卫市| 富源县| 博爱县| 文化| 梅河口市| 拉萨市| 沁水县| 盖州市| 海淀区| 南开区| 界首市| 文水县| 华容县| 郓城县| 栾川县| 普陀区| 灌云县| 浮梁县| 星子县| 中阳县| 望谟县| 永新县| 房产| 巴东县| 牡丹江市| 繁峙县| 临江市| 卓尼县| 措勤县| 林口县| 海晏县| 平湖市| 深水埗区| 富顺县| 高邑县| 克东县| 石首市| 秀山| 定襄县| 浦东新区|