设计模式之外观模式(结构型)

一、模式定义

外观模式:外观模式就是提供一个统一的接口,用来访问子系统的一群接口。外观模式定义了一个高层接口,让子系统更容易使用。,外观模式也称门面模式,是一种对象结构型设计模式。

二、模式角色

从模式定义可以知道,外观模式应该包含如下角色:

  • Frcade:外观角色
  • SubSystem:子系统角色
  • Client:客户端角色

经典例子:

public class Facade
{
    private SubSystemA obj1 = new SubSystemA();
    private SubSystemB obj2 = new SubSystemB();
    private SubSystemC obj3 = new SubSystemC();
    public void method()
    {
        obj1.method();
        obj2.method();
        obj3.method();
    }
} 

三、模式简单分析

外观模式为客户端类提供了便捷,客户端类不需要关注子系统的设计,直接提供外观类访问就好

外观模式符合“迪米特法则”,引入一个单一简单的接口,给客户端调用,从而降低了客户端和子系统的耦合度

不过外观模式也有一些缺点,每一种设计模式都是有缺点和优点的,需要根据复杂的业务场景进行选用。假如没引用一个抽象的外观类的话,一旦业务改变就需要进行外观类和客户端类代码的调整了

对于一些很复杂的业务系统来说,有时候可以设计多个外观类进行系统解耦

四、简单例子实践

JDBC数据库操作的例子,本例子来自《设计模式》一书

import java.sql.*;

public class JDBCFacade {
    
    private Connection conn=null;
    private Statement statement=null;

    public void open(String driver,String jdbcUrl,String userName,String userPwd) {
        try {
            Class.forName(driver).newInstance();
            conn = DriverManager.getConnection(jdbcUrl,userName,userPwd);
            statement = conn.createStatement();
        } 
        catch (Exception e) {
            e.printStackTrace();
        }
    }

    public int executeUpdate(String sql) {
        try {
            return statement.executeUpdate(sql);
        } 
        catch (SQLException e) {
            e.printStackTrace();
            return -1;
        }
    }

    public ResultSet executeQuery(String sql) {
        try {
            return statement.executeQuery(sql);
        } catch (SQLException e) {
            e.printStackTrace();
            return null;
        }
    }

    public void close() {
        try {
            conn.close();
            statement.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

五、模式应用

外观模式适用于复杂的系统,可以用于系统解耦。下面简单列举一下外观模式的一些应用场景

  • JavaEE框架里的Session就是用了外观模式
  • 学JSP的JDBC数据库操作也是经常用外观模式的

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏JavaEdge

电商数据库设计及架构优化实战(一) - 制定数据库开发规范

当前很多应用都适用字符串char(15)来存储IP地址(占用16个字节),利用INET_ATON和INET_NTOA函数,来存储IP地址效率很高,使用un...

16940
来自专栏信数据得永生

米斯特白帽培训讲义 漏洞篇 XSS

我们看到,这段代码中首先包含一个表单,用于向页面自己发送 GET 请求,带一个名为xss的参数。 然后 PHP 会读取该参数,如果不为空,则直接打印出来,我们看...

14530
来自专栏JAVA技术zhai

微服务开发中的数据架构设计

微服务是当前非常流行的技术框架,通过服务的小型化、原子化以及分布式架构的弹性伸缩和高可用性,可以实现业务之间的松耦合、业务的灵活调整组合以及系统的高可用性。为业...

11320
来自专栏JAVA技术zhai

掌握这几种微服务模式让你成为更出色的工程师

导读:对于很多工程师来说,进入微服务领域是很困难的。99%的服务属于五类之一,通过这种方式划分责任考虑如何通过管道服务一起管理特性,就像在Unixshell脚本...

15430
来自专栏容器化

手把手学会MySql主从配置

CREATE USER 'mysync'@'masterhostaddr' IDENTIFIED BY '123123'; GRANT REPLICATION...

16640
来自专栏JAVA技术zhai

干货:分布式系统学习笔记

比如海量数据,单机存储不下,需要多机,以集群的方式存储,即为数据的分布式存储,数据存储的分布式一般涉及如下几个方面

10730
来自专栏JAVA技术zhai

互联网企业如何应对网站架构演化带来的“蝴蝶效应”

摘要: 大型网站的挑战主要来自庞大的用户,高并发的访问和海量数据,任何简单的业务一旦需要处理数以P计的数据和面对数以亿计的用户,问题就会变得棘手。大型网站架构主...

13560
来自专栏信数据得永生

米斯特白帽培训讲义 实战篇 南方 0day

我们打算检测其中的 SQL 注入漏洞,由于 ASP 代码基本没有什么好的过滤,一般一查一个准。为了搜索 SQL 注入漏洞,我们可以使用sql、conn这类名称、...

14850
来自专栏JAVA技术zhai

微服务开发中的数据架构设计

微服务是当前非常流行的技术框架,通过服务的小型化、原子化以及分布式架构的弹性伸缩和高可用性,可以实现业务之间的松耦合、业务的灵活调整组合以及系统的高可用性。为业...

10950
来自专栏信数据得永生

米斯特白帽培训讲义(v2)漏洞篇 XSS

跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets,CSS)的缩写混淆,故将跨站脚本攻击缩...

14060

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励