设计模式 -结构型模式_门面模式(外观模式) Facade Pattern 在开源软件中的应用

简介: 设计模式 -结构型模式_门面模式(外观模式) Facade Pattern 在开源软件中的应用

Pre

我们先来回顾下门面/外观模式Facade Pattern的定义及基本使用,然后我们在开源软件中来看下是如何实践的。


定义

Facade Pattern 为子系统中的一组接口提供一个一致的入口,该模式定义了一个高层接口,这个接口呢使得第三方更加容易调用该系统,而无需关注内部的细节实现。


案例

有个大项目要搞, 最开始的时候 很小的团队 ,老大带着前端、后端、移动端、集成、测试这几个人一起搞,随着项目越来越复杂,老大是在是忙不过来了,老大要搞清楚每个人的工作,耦合性太高了。。。。。后来老大招了一个项目经理,从此老大只对接项目经理,不关心太细节的东西了,细节的实现由项目经理对接开发人员。


Demo

public class FrontEndGroup {
    public void frontGaoShiqing(){
        System.out.println("FrontEndGroup 搞事情~");
    }
}
public class BackGroudEndGroup {
    public void bgGaoShiqing(){
        System.out.println("BackGroudEndGroup 搞事情~");
    }
}
public class MobileAppGroup {
    public void appGaoShiqing(){
        System.out.println("MobileAppGroup 搞事情~");
    }
}
public class TestGroup {
    public void testGaoShiqing(){
        System.out.println("TestGroup 搞事情~");
    }
}

V1.0 Boss直接管理

public class Boss {
    public static void main(String[] args) {
        FrontEndGroup frontEndGroup = new FrontEndGroup();
        BackGroudEndGroup backGroudEndGroup = new BackGroudEndGroup();
        MobileAppGroup mobileAppGroup = new MobileAppGroup();
        TestGroup testGroup = new TestGroup();
        frontEndGroup.frontGaoShiqing();
        backGroudEndGroup.bgGaoShiqing();
        mobileAppGroup.appGaoShiqing();
        testGroup.testGaoShiqing();
    }
}

V2.0 引入外观类 PmManagerFacade

public class PmManagerFacade {
    FrontEndGroup frontEndGroup;
    BackGroudEndGroup backGroudEndGroup;
    MobileAppGroup mobileAppGroup;
    TestGroup testGroup;
    public PmManagerFacade() {
        frontEndGroup = new FrontEndGroup();
        backGroudEndGroup = new BackGroudEndGroup();
        mobileAppGroup = new MobileAppGroup();
        testGroup = new TestGroup();
    }
    public void pmGaoShiQing() {
        frontEndGroup.frontGaoShiqing();
        backGroudEndGroup.bgGaoShiqing();
        mobileAppGroup.appGaoShiqing();
        testGroup.testGaoShiqing();
    }
    public void pmGaoShiQing2() {
        backGroudEndGroup.bgGaoShiqing();
        testGroup.testGaoShiqing();
    }
}

外观类,需要了解所有的要调用的系统的方法或者属性,进行按需组合,以备外部调用。

调用如下

public class Boss {
    public static void main(String[] args) {
        PmManagerFacade pmManager = new PmManagerFacade();
        pmManager.pmGaoShiQing();
        pmManager.pmGaoShiQing2();
    }
}

main方法就相当于Boss的工作,现在他对接的是外观类Facade , 是不是很符合依赖倒转的原则和迪米特法则的思想【最少知识原则】?

其实我们常用的Controller – Service --Dao 也蕴含了外观模式的思想 。


何时使用Facade

总结一下哈

  • 系统设计阶段,要有分层的概念
  • 开发阶段,随着系统越来越庞大,可适当增加外观Facade提供简单的接口,减少依赖关系
  • 维护老系统,为了屏蔽业务的复杂性(祖传代码,能不动就不动,谁动谁背锅 哈哈哈) ,可以提供一个Facade类,让新对接的系统对接Facade类,Facade负责与遗留代码进行交互,

Tomcat

org.apache.catalina.connector.RequestFacade  

看名字 肯定是个外观模式的例子

RequestFacade 和 Request 实现了HttpServletRequest接口 。

来看下 RequestFacade 包装了Request的啥

/**
     * The wrapped request.
     */
    protected Request request = null;
   /**
     * Construct a wrapper for the specified request.
     *
     * @param request The request to be wrapped
     */
    public RequestFacade(Request request) {
        this.request = request;
    }
 @Override
    public Object getAttribute(String name) {
        if (request == null) {
            throw new IllegalStateException(
                            sm.getString("requestFacade.nullRequest"));
        }
        return request.getAttribute(name);
    }
.....
.....

RequestFacade 源码中可以看到,当调用 getAttribute() 方法时,其实还是调用了Request 对象的getAttribute() 方法。

为什么要弄个 RequestFacade 呢 ,其实是为了安全和方便调用,Tomcat 不想暴露过多的方法。


Mybatis

MyBatis的整体架构中, SQLSession负责对外提供服务,屏蔽后面Executor和StatementHandler的复杂处理, 也是一种门面模式

来看下基本用法 就能体会到了

@Test
    public void sessionTest(){
        SqlSession sqlSession = factory.openSession(ExecutorType.REUSE,true);
        // 门面模式  降低调用复杂性
        List<Object> list = sqlSession.selectList("com.artsasin.UserMapper.selectByid", 10);
        System.out.println(list.get(0));
    }

SqlSession 的默认实现是 DefaultSqlSession , DefaultSqlSession 中有个属性 Executor ,屏蔽了外部对Executor的复杂调用,仅和SqlSession交互即可,简化调用。



相关文章
|
8月前
|
设计模式 存储 缓存
【设计模式】【结构型模式】享元模式(Flyweight)
一、入门 什么是享元模式? 享元模式(Flyweight Pattern)是一种结构型设计模式,旨在通过共享对象来减少内存使用,特别适用于存在大量相似对象的情况。 它的核心思想是将对象的内在状态(不变
300 16
|
4月前
|
设计模式 人工智能 算法
基于多设计模式的状态扭转设计:策略模式与责任链模式的实战应用
接下来,我会结合实战案例,聊聊如何用「策略模式 + 责任链模式」构建灵活可扩展的状态引擎,让抽奖系统的状态管理从「混乱战场」变成「有序流水线」。
|
5月前
|
设计模式 XML 安全
Java枚举(Enum)与设计模式应用
Java枚举不仅是类型安全的常量,还具备面向对象能力,可添加属性与方法,实现接口。通过枚举能优雅实现单例、策略、状态等设计模式,具备线程安全、序列化安全等特性,是编写高效、安全代码的利器。
|
8月前
|
设计模式 Java 数据库连接
【设计模式】【结构型模式】代理模式(Proxy)
一、入门 什么是代理模式? 代理模式(Proxy Pattern)是一种结构型设计模式,允许你提供一个代理对象来控制对另一个对象的访问。 代理对象在客户端和目标对象之间起到中介作用,可以在不改变目标对
250 10
|
8月前
|
设计模式 Java 定位技术
【设计模式】【结构型模式】组合模式(Composite)
一、入门 什么是组合模式 组合模式(Composite Pattern)是一种结构型设计模式,它允许你将对象组合成树形结构来表示“部分-整体”的层次关系。组合模式使得客户端可以统一处理单个对象和组合对
280 10
|
8月前
|
关系型数据库 Java MySQL
【设计模式】【结构型模式】桥接模式(Bridge)
一、入门 什么是桥接模式? 桥接模式(Bridge Pattern)是一种结构型设计模式,核心思想是将抽象与实现分离,让它们可以独立变化。简单来说,它像一座“桥”连接了两个维度的变化,避免用继承导致代
446 10
|
8月前
|
设计模式 前端开发 Java
【设计模式】【结构型模式】适配器模式(Adpter)
一、入门 什么是适配器模式? 适配器模式是Java中常用的结构型设计模式,它的核心作用就像现实中的电源转换器一样---让原本不兼容的两个接口能够协同工作。 为什么要用适配器模式? 假设我们需要在电商系
220 10
|
8月前
|
设计模式 Java 数据库连接
【设计模式】【结构型模式】外观模式(Facde)
一、入门 什么是外观模式? 一种结构型设计模式,通过为子系统中的一组接口提供一个统一的高层接口(称为外观),来简化客户端与复杂子系统的交互过程。其本质是建立抽象层来隔离复杂度。 为什么要有外观模式?
343 9
|
8月前
|
设计模式 缓存 安全
【设计模式】【结构型模式】装饰者模式(Decorator)
一、入门 什么是装饰者模式? 装饰者模式(Decorator Pattern)是 Java 中常用的结构型设计模式,它能在不修改原有对象结构的前提下,动态地为对象添加额外的职责。 为什么要装饰者模式?
209 8
|
设计模式 缓存 应用服务中间件
「全网最细 + 实战源码案例」设计模式——外观模式
外观模式(Facade Pattern)是一种结构型设计模式,旨在为复杂的子系统提供一个统一且简化的接口。通过封装多个子系统的复杂性,外观模式使外部调用更加简单、易用。例如,在智能家居系统中,外观类可以同时控制空调、灯光和电视的开关,而用户只需发出一个指令即可。
313 69