首页 > 学院 > 开发设计 > 正文

外观模式(Fa?ade pattern)(1)

2019-11-18 13:42:47
字体:
来源:转载
供稿:网友

描述

外观模式(Façade pattern)涉及到子系统的一些类。所谓子系统,是为提供一系列相关的特征(功能)而紧密关联的一组类。例如,一个Account类、Address类和CreditCard类相互关联,成为子系统的一部分,提供在线客户的特征。

在真实的应用系统中,一个子系统可能由很多类组成。子系统的客户为了它们的需要,需要和子系统中的一些类进行交互。客户和子系统的类进行直接的交互会导致客户端对象和子系统之间高度耦合。任何的类似于对子系统中类的接口的修改,会对依靠于它的所有的客户类造成影响。

外观模式(Façade pattern)很适用于在上述情况。外观模式(Façade pattern)为子系统提供了一个更高层次、更简单的接口,从而降低了子系统的复杂度和依靠。这使得子系统更易于使用和治理。

外观是一个能为子系统和客户提供简单接口的类。当正确的应用外观,客户不再直接和子系统中的类交互,而是与外观交互。外观承担与子系统中类交互的责任。实际上,外观是子系统与客户的接口,这样外观模式降低了子系统和客户的耦合度。

我们可以看到:外观对象隔离了客户和子系统对象,从而降低了耦合度。当子系统中的类进行改变时,客户端不会像以前一样受到影响。

尽管客户使用由外观提供的简单接口,但是当需要的时候,客户端还是可以视外观不存在,直接访问子系统中的底层次的接口。这种情况下,它们之间的依靠/耦合度和原来一样。

例子:

让我们建立一个应用:

(1)    接受客户的具体资料(账户、地址和信用卡信息)

(2)    验证输入的信息

(3)    保存输入的信息到相应的文件中。

这个应用有三个类:Account、Address和CreditCard。每一个类都有自己的验证和保存数据的方法。

Listing 22.1: AccountClass 

  1. public class Account { 
  2.   String firstName; 
  3.   String lastName; 
  4.   final String ACCOUNT_DATA_FILE = "AccountData.txt"; 
  5.   public Account(String fname, String lname) { 
  6.     firstName = fname; 
  7.     lastName = lname; 
  8.   } 
  9.   public boolean isValid() { 
  10.     /* 
  11.      Let's go with simpler validation 
  12.      here to keep the example simpler. 
  13.     */ 
  14.         … 
  15.         … 
  16.   } 
  17.   public boolean save() { 
  18.     FileUtil futil = new FileUtil(); 
  19.     String dataLine = getLastName() + ”," + getFirstName(); 
  20.     return futil.writeToFile(ACCOUNT_DATA_FILE, dataLine, 
  21.     truetrue); 
  22.   } 
  23.   public String getFirstName() { 
  24.     return firstName; 
  25.   } 
  26.   public String getLastName() { 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表