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



相关文章
|
2月前
|
设计模式 PHP
PHP中的设计模式:单一职责原则在软件开发中的应用
【10月更文挑战第8天】 在软件开发中,设计模式是解决常见问题的经验总结,而单一职责原则作为面向对象设计的基本原则之一,强调一个类应该只有一个引起变化的原因。本文将探讨单一职责原则在PHP中的应用,通过实际代码示例展示如何运用该原则来提高代码的可维护性和可扩展性。
34 1
|
2月前
|
设计模式 算法 搜索推荐
后端开发中的设计模式应用与实践
在软件开发的广袤天地中,后端技术如同构筑高楼大厦的钢筋水泥,支撑起整个应用程序的骨架。本文旨在通过深入浅出的方式,探讨后端开发领域内不可或缺的设计模式,这些模式犹如精雕细琢的工具箱,能够助力开发者打造出既健壮又灵活的系统架构。从单例模式到工厂模式,从观察者模式到策略模式,每一种设计模式都蕴含着深刻的哲理与实践价值,它们不仅仅是代码的组织方式,更是解决复杂问题的智慧结晶。
|
3月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。
|
3月前
|
设计模式 算法 测试技术
PHP中的设计模式:策略模式的应用与实践
在软件开发的浩瀚海洋中,设计模式如同灯塔,指引着开发者们避开重复造轮子的暗礁,驶向高效、可维护的代码彼岸。今天,我们将聚焦于PHP领域中的一种重要设计模式——策略模式,探讨其原理、应用及最佳实践,揭示如何通过策略模式赋予PHP应用灵活多变的业务逻辑处理能力,让代码之美在策略的变换中熠熠生辉。
|
25天前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
29 2
|
1月前
|
设计模式 监控 算法
Python编程中的设计模式应用与实践感悟###
在Python这片广阔的编程疆域中,设计模式如同导航的灯塔,指引着开发者穿越复杂性的迷雾,构建出既高效又易于维护的代码结构。本文基于个人实践经验,深入探讨了几种核心设计模式在Python项目中的应用策略与实现细节,旨在为读者揭示这些模式背后的思想如何转化为提升软件质量的实际力量。通过具体案例分析,展现了设计模式在解决实际问题中的独特魅力,鼓励开发者在日常编码中积极采纳并灵活运用这些宝贵的经验总结。 ###
|
22天前
|
设计模式 开发者 Python
Python编程中的设计模式应用与实践感悟####
本文作为一篇技术性文章,旨在深入探讨Python编程中设计模式的应用价值与实践心得。在快速迭代的软件开发领域,设计模式如同导航灯塔,指引开发者构建高效、可维护的软件架构。本文将通过具体案例,展现设计模式如何在实际项目中解决复杂问题,提升代码质量,并分享个人在实践过程中的体会与感悟。 ####
|
1月前
|
设计模式 存储 数据库连接
PHP中的设计模式:单例模式的深入理解与应用
【10月更文挑战第22天】 在软件开发中,设计模式是解决特定问题的通用解决方案。本文将通过通俗易懂的语言和实例,深入探讨PHP中单例模式的概念、实现方法及其在实际开发中的应用,帮助读者更好地理解和运用这一重要的设计模式。
20 1
|
2月前
|
设计模式 PHP 开发者
PHP中的设计模式:桥接模式的解析与应用
在软件开发的浩瀚海洋中,设计模式如同灯塔一般,为开发者们指引方向。本文将深入探讨PHP中的一种重要设计模式——桥接模式。桥接模式巧妙地将抽象与实现分离,通过封装一个抽象的接口,使得实现和抽象可以独立变化。本文将阐述桥接模式的定义、结构、优缺点及其应用场景,并通过具体的PHP示例代码展示如何在实际项目中灵活运用这一设计模式。让我们一起走进桥接模式的世界,感受它的魅力所在。
|
2月前
|
设计模式 测试技术 持续交付
架构视角下的NHibernate:设计模式与企业级应用考量
【10月更文挑战第13天】随着软件开发向更复杂、更大规模的应用转变,数据访问层的设计变得尤为重要。NHibernate作为一个成熟的对象关系映射(ORM)框架,为企业级.NET应用程序提供了强大的支持。本文旨在为有一定经验的开发者提供一个全面的指南,介绍如何在架构层面有效地使用NHibernate,并结合领域驱动设计(DDD)原则来构建既强大又易于维护的数据层。
40 2