设计模式 -结构型模式_门面模式(外观模式) 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交互即可,简化调用。



相关文章
|
1月前
|
设计模式 算法 C++
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程(二)
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程
27 0
|
1月前
|
设计模式 存储 uml
C++ 设计模式实战:外观模式和访问者模式的结合使用,派生类访问基类的私有子系统
C++ 设计模式实战:外观模式和访问者模式的结合使用,派生类访问基类的私有子系统
29 1
|
1月前
|
设计模式 编解码 C++
【ffmpeg 视频播放】深入探索:ffmpeg视频播放优化策略与设计模式的实践应用(一)
【ffmpeg 视频播放】深入探索:ffmpeg视频播放优化策略与设计模式的实践应用
50 0
|
1月前
|
设计模式 存储 缓存
【ffmpeg 视频播放】深入探索:ffmpeg视频播放优化策略与设计模式的实践应用(二)
【ffmpeg 视频播放】深入探索:ffmpeg视频播放优化策略与设计模式的实践应用
27 0
|
1月前
|
设计模式 存储 安全
Java设计模式---结构型模式
Java设计模式---结构型模式
|
3月前
|
设计模式
设计模式-外观模式
设计模式-外观模式
31 0
|
9天前
|
设计模式 算法 Java
Java中的设计模式及其应用
【4月更文挑战第18天】本文介绍了Java设计模式的重要性及分类,包括创建型、结构型和行为型模式。创建型模式如单例、工厂方法用于对象创建;结构型模式如适配器、组合关注对象组合;行为型模式如策略、观察者关注对象交互。文中还举例说明了单例模式在配置管理器中的应用,工厂方法在图形编辑器中的使用,以及策略模式在电商折扣计算中的实践。设计模式能提升代码可读性、可维护性和可扩展性,是Java开发者的必备知识。
|
13天前
|
设计模式 存储 Java
Java设计模式:解释一下单例模式(Singleton Pattern)。
`Singleton Pattern`是Java中的创建型设计模式,确保类只有一个实例并提供全局访问点。它通过私有化构造函数,用静态方法返回唯一的实例。类内静态变量存储此实例,对外仅通过静态方法访问。
16 1
|
1月前
|
设计模式 算法 中间件
【C++ 可调用对象的应用】C++设计模式与现代编程技巧:深入可调用对象的世界
【C++ 可调用对象的应用】C++设计模式与现代编程技巧:深入可调用对象的世界
114 1
|
1月前
|
设计模式 编解码 算法
【ffmpeg 视频播放】深入探索:ffmpeg视频播放优化策略与设计模式的实践应用(三)
【ffmpeg 视频播放】深入探索:ffmpeg视频播放优化策略与设计模式的实践应用
29 0