java设计模式之外观模式(Facade)

概述

外部与内部子系统通信时必须通过的一个统一的外观模式对象进行,就是外观模式,也称门面模式。一般而言,Facade模式是为了降低客户端与实现化层之间的依赖性。外观模式的用意是为子系统提供一个集中化和简化的沟通渠道。

UML类图

在上面的UML图中,出现三个角色:

客户端角色(Client):用户通过客户端来调用外观模式的类,从而来操作子系统;

外观角色(Facade):客户端可以调用这个类,此类中包含了调用子系统中具体的功能;

子系统角色(Module):定义了子系统中具体的单个功能;

代码示例:

package interview;

class ModuleA {

public void testA(){

System.out.println("ModuleA 中的方法");

}

}

class ModuleB {

public void testB(){

System.out.println("ModuleB 中的方法");

}

}

class ModuleC {

public void testC(){

System.out.println("ModuleC 中的方法");

}

}

class Facade{

public void testA(){

ModuleA moduleA = new ModuleA();

moduleA.testA();

}

public void testB(){

ModuleB moduleB = new ModuleB();

moduleB.testB();

}

public void testC(){

ModuleC moduleC = new ModuleC();

moduleC.testC();

}

}

public class MainTest {

public static void main(String arg[]) {

Facade facade = new Facade();

facade.testA();

facade.testB();

facade.testC();

}

}

上述代码中Facade类充当了ModuleA ,ModuleB,ModuleC模块的外观界面,通过这个类,客户端不需要亲自调用子系统的ABC模块,也不需要知道系统内部的细节,从而更好的实现了客户端与系统的解耦。

同时,使用外观模式,还可以选择性的暴露方法,一个模块中定义的方法可以分成两部分,一部分是给子系统外部使用的,一部分是子系统内部模块之间相互调用时使用的。

外观模式的优点

外观模式松散了客户端与子系统的耦合关系,让子系统内部的模块能更容易扩展和维护。

让子系统更加易用,客户端不再需要了解子系统内部的实现,也不需要跟众多子系统内部的模块进行交互,只需要跟外观类交互就可以了。

可以帮助我们更好地划分访问的层次。有些方法是对系统外的,有些方法是系统内部使用的。把需要暴露给外部的功能集中到门面中,这样既方便客户端使用,也很好地隐藏了内部的细节。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是 java设计模式之外观模式(Facade) 的全部内容, 来源链接: utcz.com/p/211107.html

回到顶部