java设计模式之中介者模式
1、定义:用一个中介对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
2、代码实现
/** * 抽象中介者 */ public abstract class AbstractMediator { protected Purchase purchase; protected Sale sale; protected Stock stock; //构造函数 public AbstractMediator(){ purchase = new Purchase(this); sale = new Sale(this); stock = new Stock(this); } //中介者最重要的方法叫做事件方法, 处理多个对象之间的关系 public abstract void execute(String str,Object...objects); }
/** * 中介者 */ public class Mediator extends AbstractMediator { //中介者最重要的方法 @Override public void execute(String str, Object... objects) { if (str.equals("purchase.buy")){ //采购电脑 this.buyComputer((Integer)objects[0]); }else if(str.equals("sale.sell")){ //销售电脑 this.sellComputer((Integer)objects[0]); }else if(str.equals("sale.offsell")){ //折价销售 this.offSell(); }else if(str.equals("stock.clear")){ //清仓处理 this.clearStock(); } } //采购电脑 private void buyComputer(int number){ int saleStatus = super.sale.getSaleStatus(); if(saleStatus > 80){ //销售情况良好 System.out.println("采购IBM电脑:"+number + "台"); super.stock.increase(number); }else{ //销售情况不好 int buyNumber = number/2; //折半采购 System.out.println("采购IBM电脑: "+buyNumber+ "台"); super.stock.increase(buyNumber); } } //销售电脑 private void sellComputer(int number){ if(super.stock.getStockNumber()<number){ //库存数量不够销售 super.purchase.buyIBMcomputer(number); } super.stock.decrease(number); } //折价销售电脑 private void offSell(){ System.out.println("折价销售IBM电脑"+super.stock.getStockNumber()+"台"); } //清仓处理 private void clearStock(){ //要求清仓销售 super.sale.offSale(); //要求采购人员不要采购 super.purchase.refuseBuyIBM(); } }
/** * 抽象同事类 */ public abstract class AbstractColleague { protected AbstractMediator mediator; public AbstractColleague(AbstractMediator _mediator){ this.mediator = _mediator; } }
/** * 采购管理 * Purchase类处理自己的职责, 与外界有关系的事件处理则交给了中介者来完成 */ public class Purchase extends AbstractColleague { public Purchase(AbstractMediator _mediator) { super(_mediator); } //采购IBM电脑 public void buyIBMcomputer(int number){ super.mediator.execute("purchase.buy", number); } //不再采购IBM电脑 public void refuseBuyIBM(){ System.out.println("不再采购IBM电脑"); } }
/** * 销售管理 */ public class Sale extends AbstractColleague { public Sale(AbstractMediator _mediator) { super(_mediator); } //销售ibm电脑 public void sellIBMComputer(int number){ super.mediator.execute("sale.sell", number); System.out.println("销售IBM电脑"+number+"台"); } //反馈销售情况, 0~100之间变化, 0代表根本就没人卖, 100代表非常畅销, 出一个卖一个 public int getSaleStatus(){ Random rand = new Random(System.currentTimeMillis()); int saleStatus = rand.nextInt(100); System.out.println("IBM电脑的销售情况为: "+saleStatus); return saleStatus; } //折价处理 public void offSale(){ super.mediator.execute("sale.offsell"); } }
/** * 库存管理 */ public class Stock extends AbstractColleague { public Stock(AbstractMediator _mediator) { super(_mediator); } //刚开始有100台电脑 private static int COMPUTER_NUMBER = 100; //库存增加 public void increase(int number) { COMPUTER_NUMBER = COMPUTER_NUMBER + number; System.out.println("库存数量为:" + COMPUTER_NUMBER); } //库存减少 public void decrease(int number) { COMPUTER_NUMBER = COMPUTER_NUMBER - number; System.out.println("库存数量为: "+COMPUTER_NUMBER); } //获得库存数量 public int getStockNumber(){ return COMPUTER_NUMBER; } //存货压力大了, 就要通知采购人员不要采购, 销售人员要尽快销售 public void clearStock(){ System.out.println("清理存货数量为: "+COMPUTER_NUMBER); super.mediator.execute("stock.clear"); } }
/** * 测试类 */ public class Client { public static void main(String[] args) { AbstractMediator mediator = new Mediator(); //采购人员采购电脑 System.out.println("------采购人员采购电脑--------"); mediator.purchase.buyIBMcomputer(100); //销售人员销售电脑 System.out.println("\n------销售人员销售电脑--------"); mediator.sale.sellIBMComputer(1); //库房管理人员管理库存 System.out.println("\n------库房管理人员清库处理--------"); mediator.stock.clearStock(); } }
多个对象相互依赖的情况下,通过增加中介者,每个对象只处理自己的行为,与自己无关的丢给中介者处理,降低对象的耦合性,提示代码质量。
3、主要由3部分组成:
抽象中介者:抽象中介者角色定义统一的接口,用于各同事角色之间的通信。
具体中介者:具体中介者角色通过协调各同事角色实现协作行为,因此它必须依赖于各个同事角色。
同事角色:每一个同事角色都知道中介者角色,而且与其他的同事角色通信的时候,一定要通过中介者角色协作。
同事类必须有中介者,而中介者却可以只有部分同事类。
4、优点
减少类间的依赖, 把原有的一对多的依赖变成了一对一的依赖,同事类只依赖中介者,减少了依赖,当然同时也降低了类间的耦合。
5、缺点
中介者会膨胀得很大,而且逻辑复杂,原本N个对象直接的相互依赖关系转换为中介者和同事类的依赖关系,同事类越多,中介者的逻辑就越复杂。
6、使用场景
中介者模式适
用于多个对象之间紧密耦合的情况,紧密耦合的标准是:在类图中出现了蜘蛛网状结构。在这种情况下一定要考虑使用中介者模式,这有利于把蜘蛛网梳理为星型结构,使原本复杂混
乱的关系变得清晰简单。