Java门面Facade设计模式

开发 前端
门面Facade模式很常用,比如Slf4j日志门面,只需要简单使用日志框架的接口调用,而无需理会背后的日志框架实现是使用logback还是log4j2。

概述

简单地说,门面Facade将一个复杂的子系统封装在一个简单的接口后面。它隐藏了许多复杂性,并使子系统易于使用。

此外,如果我们需要直接使用复杂的子系统,仍然可以,并没有必须一直使用门面接口。

除了更简单的界面之外,使用这种设计模式还有一个好处,它将客户端实现与复杂的子系统解耦。多亏了这一点,我们可以对现有的子系统进行更改,而不会影响客户端。

示例

比方说我们想发动一辆汽车。下图表示遗留系统,它允许我们这样做:

正如所看到的,流程可能非常复杂才能正确启动发动机:

airFlowController.takeAir()
fuelInjector.on()
fuelInjector.inject()
starter.start()
coolingController.setTemperatureUpperLimit(DEFAULT_COOLING_TEMP)
coolingController.run()
catalyticConverter.on()

同样,停止发动机也需要相当多的步骤:

fuelInjector.off()
catalyticConverter.off()
coolingController.cool(MAX_ALLOWED_TEMP)
coolingController.stop()
airFlowController.off()

门面正是这里所需要的,我们将在两个方法中隐藏所有的复杂性:startEngine()和stopEngine():

public class CarEngineFacade {
    private static int DEFAULT_COOLING_TEMP = 90;
    private static int MAX_ALLOWED_TEMP = 50;
    private FuelInjector fuelInjector = new FuelInjector();
    private AirFlowController airFlowController = new AirFlowController();
    private Starter starter = new Starter();
    private CoolingController coolingController = new CoolingController();
    private CatalyticConverter catalyticConverter = new CatalyticConverter();

    public void startEngine() {
        fuelInjector.on();
        airFlowController.takeAir();
        fuelInjector.on();
        fuelInjector.inject();
        starter.start();
        coolingController.setTemperatureUpperLimit(DEFAULT_COOLING_TEMP);
        coolingController.run();
        catalyticConverter.on();
    }

    public void stopEngine() {
        fuelInjector.off();
        catalyticConverter.off();
        coolingController.cool(MAX_ALLOWED_TEMP);
        coolingController.stop();
        airFlowController.off();
    }

现在,要启动和停止汽车,我们只需要2行代码,而不是13行:

facade.startEngine();
// ...
facade.stopEngine();

缺点

Facade模式只添加了额外的抽象层。有时,在简单的场景中可能会过度使用该模式,这将导致冗余的实现。

结论

门面Facade模式很常用,比如Slf4j日志门面,只需要简单使用日志框架的接口调用,而无需理会背后的日志框架实现是使用logback还是log4j2。

责任编辑:武晓燕 来源: 今日头条
相关推荐

2021-03-18 15:33:22

设计模式外观

2024-02-19 13:11:38

门面模式系统

2021-04-18 21:07:32

门面模式设计

2022-02-15 22:45:00

前端设计模式

2022-11-14 08:44:56

前端门面模式接口

2021-07-11 06:46:17

前端设计模式

2021-06-02 08:17:05

门面模式设计

2023-10-26 18:08:36

API网关性能

2009-06-15 14:19:55

Java设计模式Java

2012-03-28 13:28:56

Java设计模式

2012-05-16 17:22:11

Java设计模式

2011-11-17 16:03:05

Java工厂模式Clojure

2012-05-16 17:15:04

Java设计模式

2021-02-01 10:01:58

设计模式 Java单例模式

2023-11-02 21:11:11

JavaScript设计模式

2013-05-23 15:59:00

线程池

2009-07-08 09:32:25

Java设计模式

2022-01-12 13:33:25

工厂模式设计

2023-05-04 08:47:31

命令模式抽象接口

2020-10-23 09:40:26

设计模式
点赞
收藏

51CTO技术栈公众号