java 门面模式_java设计模式之外观模式(门面模式)

针对外观模式,在项目开发和实际运用中十分频繁,但是其极易理解,下面就简要介绍一下。

一、概念介绍

外观模式(Facade),他隐藏了系统的复杂性,并向客户端提供了一个可以访问系统的接口。这种类型的设计模式属于结构性模式。为子系统中的一组接口提供了一个统一的访问接口,这个接口使得子系统更容易被访问或者使用。

二、角色及使用场景

123139debe34fd28738ad3a08593f796.png

简单来说,该模式就是把一些复杂的流程封装成一个接口供给外部用户更简单的使用。这个模式中,设计到3个角色。

1).门面角色:外观模式的核心。它被客户角色调用,它熟悉子系统的功能。内部根据客户角色的需求预定了几种功能的组合。

2).子系统角色:实现了子系统的功能。它对客户角色和Facade时未知的。它内部可以有系统内的相互交互,也可以由供外界调用的接口。

3).客户角色:通过调用Facede来完成要实现的功能。

使用场景:

1- 为复杂的模块或子系统提供外界访问的模块;

2- 子系统相互独立;

3- 在层析结构中,可以使用外观模式定义系统的每一层的入口。

三、实例

下面,我们就通过一个简单的例子来实现该模式。

每个Computer都有CPU、Memory、Disk。在Computer开启和关闭的时候,相应的部件也会开启和关闭,所以,使用了该外观模式后,会使用户和部件之间解耦。如:

8f1a5aad420c55c2d84d2f076bcc7669.png

包体的创建:

c3a828e61fa70b120d7573ae24686533.png

代码实现

首先是子系统类:

【代码清单--1】

1 packagecom.huawei.facadeDesign.children;2

3 importorg.apache.log4j.Logger;4

5 /**

6 * cpu子系统类7 *@authorAdministrator8 *9 */

10 public classCPU11 {12 public static final Logger LOGGER = Logger.getLogger(CPU.class);13 public voidstart()14 {15 LOGGER.info("cpu is start...");16 }17

18 public voidshutDown()19 {20 LOGGER.info("CPU is shutDown...");21 }22 }

【代码清单--2】

1 packagecom.huawei.facadeDesign.children;2

3 importorg.apache.log4j.Logger;4

5 /**

6 * Disk子系统类7 *@authorAdministrator8 *9 */

10 public classDisk11 {12 public static final Logger LOGGER = Logger.getLogger(Disk.class);13 public voidstart()14 {15 LOGGER.info("Disk is start...");16 }17

18 public voidshutDown()19 {20 LOGGER.info("Disk is shutDown...");21 }22 }

【代码清单--3】

1 packagecom.huawei.facadeDesign.children;2

3 importorg.apache.log4j.Logger;4

5 /**

6 * Memory子系统类7 *@authorAdministrator8 *9 */

10 public classMemory11 {12 public static final Logger LOGGER = Logger.getLogger(Memory.class);13 public voidstart()14 {15 LOGGER.info("Memory is start...");16 }17

18 public voidshutDown()19 {20 LOGGER.info("Memory is shutDown...");21 }22 }

然后是,门面类Facade

【代码清单--4】

1 packagecom.huawei.facadeDesign.facade;2

3 importorg.apache.log4j.Logger;4

5 importcom.huawei.facadeDesign.children.CPU;6 importcom.huawei.facadeDesign.children.Disk;7 importcom.huawei.facadeDesign.children.Memory;8

9

10 /**

11 * 门面类(核心)12 *@authorAdministrator13 *14 */

15 public classComputer16 {17 public static final Logger LOGGER = Logger.getLogger(Computer.class);18

19 privateCPU cpu;20 privateMemory memory;21 privateDisk disk;22 publicComputer()23 {24 cpu = newCPU();25 memory = newMemory();26 disk = newDisk();27 }28 public voidstart()29 {30 LOGGER.info("Computer start begin");31 cpu.start();32 disk.start();33 memory.start();34 LOGGER.info("Computer start end");35 }36

37 public voidshutDown()38 {39 LOGGER.info("Computer shutDown begin");40 cpu.shutDown();41 disk.shutDown();42 memory.shutDown();43 LOGGER.info("Computer shutDown end...");44 }45 }

最后为,客户角色。

【代码清单--5】

1 packagecom.huawei.facadeDesign;2

3 importorg.apache.log4j.Logger;4

5 importcom.huawei.facadeDesign.facade.Computer;6

7 /**

8 * 客户端类9 *@authorAdministrator10 *11 */

12 public classCilent {13 public static final Logger LOGGER = Logger.getLogger(Cilent.class);14 public static voidmain(String[] args)15 {16 Computer computer = newComputer();17 computer.start();18 LOGGER.info("=================");19 computer.shutDown();20 }21

22 }

【代码清单--6】运行结果

924c2f66005a31c5126766f90f63143a.png

从上面的实例来看,有了这个Facade类,也就是Computer类,用户就不用亲自去调用子系统中的Disk,Memory、CPU类了,不需要知道系统内部的实现细节,甚至都不用知道系统内部的构成。客户端只需要跟Facade交互就可以了。

四、优点

- 松散耦合

使得客户端和子系统之间解耦,让子系统内部的模块功能更容易扩展和维护;

- 简单易用

客户端根本不需要知道子系统内部的实现,或者根本不需要知道子系统内部的构成,它只需要跟Facade类交互即可。

- 更好的划分访问层次

有些方法是对系统外的,有些方法是系统内部相互交互的使用的。子系统把那些暴露给外部的功能集中到门面中,这样就可以实现客户端的使用,很好的隐藏了子系统内部的细节。

五、延伸及应用(补充)

...

希望对大家的学习有帮助,请多指教。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值