`
xwood
  • 浏览: 102938 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Facade(门面)模式

阅读更多

一、模式简介
      外观模式(Facade Pattern)可以将一系列复杂的类包装成一个简单的封闭接口。也称门面模式.

二、模式意图
      facade(门面)模式的作用在于降低客户端操作与Server之间的耦合度,提供统一的访问
入口供客户端使用。减少回底层变化给客户端使用带来的不便。

它适用于一组相对固定且有实际意义的操作,如去医院看病分为挂号、门诊、划价、化验、
收费、取药等。这些操作都可以由Facade来处理,病人只需要与Facade交互就可以了。

在Facade中,我们实现的只是一种事务处理的抽象,并不涉及具体的事务处理逻辑。比如
挂号,我们只需要告诉Facade我们需要挂号,Facade再去联系具体实现挂号的护士,由
护士最终实现具体挂号操作。
     
三、模式UML(下图转自http://www.dofactory.com/)


       
四、模式参与者
      门面(Facade)角色:客户端可以调用这个角色的方法。
          此角色知晓相关的(一个或者多个)子系统的功能和责任。
          在正常情况下,本角色会将所有从客户端发来的请求委派到相应的子系统去。
         
      子系统(SubSystem)角色:可以同时有一个或者多个子系统。
          实现子系统的功能,处理由Facade对象指派的任务。
          每一个子系统都不是一个单独的类,而是一个类的集合。
          每一个子系统都可以被客户端直接调用,或者被门面角色调用。
          子系统并不知道门面的存在,对于子系统而言,门面仅仅是另外一个客户端而已。

五、示例代码


1.子系统代码

public class Account {
	String firstName;
	String lastName;
	final String ACCOUNT_DATA_FILE = "AccountData.txt";
	
	
	public Account(String fname, String lname) {
	firstName = fname;
	lastName = lname;
	}
	public boolean isValid() {
		/*
		Let's go with simpler validation
		here to keep the example simpler.
		*/
		return false;
	}
	public boolean save() {
		String dataLine = getLastName() + "," + getFirstName();
		try {
			FileUtils.writeStringToFile(new File(ACCOUNT_DATA_FILE), dataLine);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			return false;
		}
		return true;
	}
	public String getFirstName() {
		return firstName;
	}
	public String getLastName() {
		return lastName;
	}
}



public class Address {
	String address;
	String city;
	String state;
	final String ADDRESS_DATA_FILE = "Address.txt";
	
	public Address(String add, String cty, String st) {
		address = add;
		city = cty;
		state = st;
	}
	public boolean isValid() {
		/*
		The address validation algorithm
		could be complex in real-world
		applications.
		Let's go with simpler validation
		here to keep the example simpler.
		*/
		if (getState().trim().length() < 2)
			return false;
		return true;
	}
	public boolean save() {
		String dataLine = getAddress() + "," + getCity() + "," +
		getState();
		try {
			FileUtils.writeStringToFile(new File(ADDRESS_DATA_FILE), dataLine);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			return false;
		}
		return true;
	}
	public String getAddress() {
		return address;
	}
	public String getCity() {
		return city;
	}
	public String getState() {
		return state;
	}
}


public class CreditCard {
	String cardType;
	String cardNumber;
	String cardExpDate;
	final String CC_DATA_FILE = "CC.txt";
	
	public CreditCard(String ccType, String ccNumber,
		String ccExpDate) {
		cardType = ccType;
		cardNumber = ccNumber;
		cardExpDate = ccExpDate;
	}
	public boolean isValid() {
		/*
		Let's go with simpler validation
		here to keep the example simpler.
		*/
		if (getCardType().equals(AccountManager.VISA)) {
			return (getCardNumber().trim().length() == 16);
		}
		if (getCardType().equals(AccountManager.DISCOVER)) {
			return (getCardNumber().trim().length() == 15);
		}
		if (getCardType().equals(AccountManager.MASTER)) {
			return (getCardNumber().trim().length() == 16);
		}
		return false;
	}
	public boolean save() {
		String dataLine =
		getCardType() + "," + getCardNumber() + "," +
		getCardExpDate();
		try {
			FileUtils.writeStringToFile(new File(CC_DATA_FILE), dataLine);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			return false;
		}
		return true;
	}
	public String getCardType() {
		return cardType;
		}
		public String getCardNumber() {
		return cardNumber;
		}
		public String getCardExpDate() {
		return cardExpDate;
	}
}




2.Facade代码

public class CustomerFacade {
	private String address;
	private String city;
	private String state;
	private String cardType;
	private String cardNumber;
	private String cardExpDate;
	private String fname;
	private String lname;
	
	public void setAddress(String inAddress) {
		address = inAddress;
	}
	public void setCity(String inCity) {
		city = inCity;
	}
	public void setState(String inState) {
		state = inState;
	}
	public void setFName(String inFName) {
		fname = inFName;
	}
	public void setLName(String inLName) {
		lname = inLName;
	}
	public void setCardType(String inCardType) {
		cardType = inCardType;
	}
	public void setCardNumber(String inCardNumber) {
		cardNumber = inCardNumber;
	}
	public void setCardExpDate(String inCardExpDate) {
		cardExpDate = inCardExpDate;
	}
	public boolean saveCustomerData() {
		Address objAddress;
		Account objAccount;
		CreditCard objCreditCard;
		/*
		client is transparent from the following
		set of subsystem related operations.
		*/
		boolean validData = true;
		String errorMessage = "";
		objAccount = new Account(fname, lname);
		if (objAccount.isValid() == false) {
			validData = false;
			errorMessage = "Invalid FirstName/LastName";
		}
		objAddress = new Address(address, city, state);
		if (objAddress.isValid() == false) {
			validData = false;
				errorMessage = "Invalid Address/City/State";
		}
		objCreditCard = new CreditCard(cardType, cardNumber,
		cardExpDate);
		if (objCreditCard.isValid() == false) {
			validData = false;
			errorMessage = "Invalid CreditCard Info";
		}
		if (!validData) {
			System.out.println(errorMessage);
			return false;
		}
		if (objAddress.save() && objAccount.save() && objCreditCard.save()) {
			return true;
		} else {
			return false;
		}
	}
}



3.客户端代码

public class AccountManager extends JFrame {
	public static final String VISA = "VISA";
	public static final String MASTER = "MASTER";
	public static final String DISCOVER = "DISCOVER"; 
	public static final String newline = "\n";
	public static final String VALIDATE_SAVE = "Validate & Save";
	private JComboBox cmbCardType;
	private JTextField txtFirstName = new JTextField();
	private JTextField txtLastName = new JTextField();
	private JTextField txtAddress = new JTextField();
	private JTextField txtCity = new JTextField();
	private JTextField txtState = new JTextField();
	private JTextField txtCardNumber = new JTextField();
	private JTextField txtDate = new JTextField();
	private JButton submit = new JButton("submit");
	
	
	private CustomerFacade customer;

	public AccountManager() {
		super(" Facade Pattern - Example ");
		cmbCardType = new JComboBox();
		cmbCardType.addItem(AccountManager.VISA);
		cmbCardType.addItem(AccountManager.MASTER);
		cmbCardType.addItem(AccountManager.DISCOVER);
		
		submit.addActionListener(new ActionListener(){

			@Override
			public void actionPerformed(ActionEvent e) {
				// TODO Auto-generated method stub
				customer = new CustomerFacade();
				if(txtFirstName.getText() != null || txtFirstName.getText() != ""){
					customer.setFName(txtFirstName.getText());
				}
				{
					//赋值操作
				}
				customer.saveCustomerData();
			}
			
		});
		GridLayout layout = new GridLayout(9,2);
		
		setLayout(layout);
		add(new JLabel("txtFirstName"));
		add(txtFirstName);
		add(new JLabel("txtLastName"));
		add(txtLastName);
		add(new JLabel("txtAddress"));
		add(txtAddress);
		add(new JLabel("txtCity"));
		add(txtCity);
		add(new JLabel("cmbCardType"));
		add(cmbCardType);
		add(new JLabel("txtCardNumber"));
		add(txtCardNumber);
		add(new JLabel("txtDate"));
		add(txtDate);
		add(new JLabel());
		add(submit);
		

	}

	public static void main(String[]args){
		JFrame f = new AccountManager();
		f.setBounds(100, 100, 600, 800);
		f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		f.setVisible(true);
	}
}

 

 

分享到:
评论

相关推荐

    设计模式之门面模式(Facade模式)

    设计模式之门面模式(Facade模式),介绍门面模式,实际例子分析,代码讲解等

    facade门面模式

    门面模式(Facade Pattern)是一种结构型设计模式,它的主要目的是为复杂的子系统提供一个统一且简单的接口,使得客户端能够更方便地与这些子系统交互,而无需了解子系统的内部实现细节。这种模式降低了客户端与子...

    C++设计模式课件14_Facade_门面模式.pdf

    ### C++设计模式之门面模式(Facade Pattern) #### 一、门面模式概述 在软件工程领域,设计模式是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易...

    设计模式C++学习之门面模式(Facade)

    门面模式(Facade)是设计模式中的一种结构型模式,它的主要目的是为了解决复杂的系统接口问题,提供一个简单的统一接口,使得客户端可以更方便地使用系统。在C++编程中,门面模式的应用尤为常见,它能有效地降低...

    迪米特法则---门面Facade模式.docx

    门面(Facade)模式是一种设计模式,遵循迪米特法则,旨在简化子系统的使用,减少客户端与子系统之间的复杂依赖关系。迪米特法则主张一个对象应该尽量减少与其他对象的交互,只与直接的朋友交流,以此提高系统的内聚...

    设计模式之Facade

    eclipse工程文件 包含代码 有助理解 门面(Facade)模式 &lt;br&gt;外部与一个子系统的通信必须通过一个统一的门面(Facade)对象进行,这就是门面模式。 &lt;br&gt;医院的例子 &lt;br&gt;用一个例子进行说明,如果把医院...

    我们考察一个保安系统的例子来讲门面(Facade)模式

    门面(Facade)模式的应用 门面(Facade)模式是结构型设计模式之一,目的是提供一个统一的接口来访问一个子系统中的一组接口。门面模式可以简化客户端对子系统的访问,减少子系统的复杂性。 在本例中,我们使用一...

    设计模式 之 “门面模式[Facade Pattern]”

    门面模式(Facade Pattern)是软件工程中一种常用的结构型设计模式,它的主要目的是提供一个统一的接口,用来简化系统中一组复杂的接口或类的使用。这个模式将复杂的子系统接口封装在一个简单的门面对象中,使得...

    结构型模式之门面模式(Facade)

    门面模式(Facade)是软件设计模式中的一种结构型模式,它的主要目的是为了解耦复杂的系统,通过提供一个简单的统一接口来屏蔽子系统的复杂性,使得客户端与子系统的交互变得更加简单和直观。在大型软件系统中,往往...

    java实现的简单的应用facade模式范例

    Facade模式,也称为门面模式,是一种结构型设计模式,它提供了一个统一的接口,用于与复杂的子系统进行交互。这个模式简化了客户端与子系统之间的交互,使得客户端只需要知道一个简单的接口,而无需了解子系统的内部...

    第8讲_门面模式(Facade)

    门面模式(Facade Pattern)是一种设计模式,它在软件工程中扮演着简化复杂系统接口的角色。当一个系统或子系统包含大量类,并且客户端需要与这些类进行交互时,门面模式可以提供一个高层次的单一接口,使得客户端的...

    Facade模式

    2. **外观(Facade)**:也称为门面,它是客户端和子系统之间的接口,隐藏了子系统的复杂性。它将客户端需要调用的子系统接口封装起来,提供给客户端一个简单的接口。 3. **客户端(Client)**:通过调用外观对象的...

    设计模式之门面模式

    门面模式(Facade Pattern)是软件工程中一种常用的设计模式,属于结构型模式。它提供了一个统一的接口,用来访问子系统中的一群接口。门面模式使得子系统的使用更为简单,同时也隐藏了子系统的复杂性,使得客户端...

    Java实现的门面模式

    门面模式(Facade Pattern)是设计模式中的一种结构型模式,它的主要目的是为了解决复杂的系统接口提供一个简单易用的统一入口。在Java中,门面模式的应用可以帮助我们更好地组织代码,降低系统的耦合度,提高代码的...

    23种设计模式--门面模式

    门面模式(Facade Pattern)是软件工程中一种常用的设计模式,属于结构型模式。它为一个复杂的子系统提供了一个统一的接口,使得客户端可以更容易地使用这个子系统,而无需了解其内部的具体实现细节。在实际开发中,...

    门面模式(代码)

    门面模式(Facade Pattern)是一种设计模式,属于结构型模式,它的主要目的是为了解耦复杂的系统,提供一个统一的入口,使得外部客户端可以更简单、更方便地与系统交互,而无需关注系统的内部实现细节。在门面模式中...

    设计模式之门面模式Java实现和类设计图

    门面模式(Facade Pattern)是软件工程中一种常用的设计模式,属于结构型模式,它提供了一个统一的接口,用于访问子系统中的一组接口。在面向对象设计中,门面模式为子系统提供了更简单的接口,使得客户端可以更容易...

    外观模式facade

    外观模式(Facade)是设计模式中的一种结构型模式,它为复杂的系统或子系统提供了一个统一的入口点,简化了客户端与系统之间的交互。通过外观模式,我们可以将系统的内部复杂性隐藏起来,使得用户只需要与一个简单的...

    门面模式门面模式

    门面模式(Facade Pattern)是一种结构型设计模式,它的主要目的是提供一个统一的接口,用来访问子系统中的一组接口。这个接口使得子系统更容易使用,同时也减少了客户端代码与子系统之间的耦合。门面模式通常用于...

Global site tag (gtag.js) - Google Analytics