中介者模式 Love The Way You Lie 2022-03-14 15:42 249阅读 0赞 > 中介者模式适用于,完成一件事情,需要多方面协同合作,而多方面之间的耦合性较紧密 有一个场景 采购部门要采购IBM的电脑,它根据以下两个要素来决定采购数量。 * 销售情况 销售部门要反馈销售情况,畅销就多采购,滞销就不采购。 * 库存情况 即使是畅销产品,库存都有1000台了,每天才卖出去10台,也就不需要再采购了! 销售模块是企业的赢利核心,对其他两个模块也有影响: * 库存情况 库房有货,才能销售,空手套白狼是不行的。 * 督促采购 在特殊情况下,比如一个企业客户要一次性购买100台电脑,库存只有80台,这时需要 催促采购部门赶快采购! 从以上分析来看,这三个模块都有自己的行为,并且与其他模块之间的行为产生关联, 类似于我们办公室的同事,大家各干各的活,但是彼此之间还是有交叉的,于是彼此之间就 产生紧耦合 #### 采购管理 #### public class Purchase { // 采购IBM电脑 public void buyIBMcomputer(int number) { // 访问库存 Stock stock = new Stock(); // 访问销售 Sale sale = new Sale(); // 电脑的销售情况 int saleStatus = sale.getSaleStatus(); if (saleStatus > 80) { // 销售情况良好 System.out.println("采购IBM电脑:" + number + "台"); stock.increase(number); } else { // 销售情况不好, 折半采购 int buyNumber = number / 2; System.out.println("采购IBM电脑:" + buyNumber + "台"); stock.increase(buyNumber); } } // 不再采购IBM电脑 public void refuseBuyIBM() { System.out.println("不再采购IBM电脑"); } } #### 库存管理 #### public class Stock { //刚开始有100台电脑 private static int COMPUTER_NUMBER = 100; //库存增加 public void increase(int number) { COMPUTER_NUMBER += number; System.out.println("库存数量为:" + COMPUTER_NUMBER); } //库存降低 public void decrease(int number) { COMPUTER_NUMBER -= number; System.out.println("库存数量为:" + COMPUTER_NUMBER); } //获得库存数量 public int getStockNumber() { return COMPUTER_NUMBER; } //存货压力大了,就要通知采购人员不要采购,销售人员要尽快销售 public void clearStock() { Purchase purchase = new Purchase(); Sale sale = new Sale(); System.out.println("清理存货数量为:" + COMPUTER_NUMBER); //要求折价销售 sale.offSale(); //要求采购人员不要采购 purchase.refuseBuyIBM(); } } #### 销售管理 #### public class Sale { //销售IBM电脑 public void sellIBMComputer(int number) { //访问库存 Stock stock = new Stock(); //访问采购 Purchase purchase = new Purchase(); while (stock.getStockNumber() < number) { // 库存数量不够销售 purchase.buyIBMcomputer(number); } System.out.println("销售IBM电脑" + number + "台"); stock.decrease(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() { //库房有多少卖多少 Stock stock = new Stock(); System.out.println("折价销售IBM电脑" + stock.getStockNumber() + "台"); } } #### 场景类 #### public class Client { public static void main(String[] args) { //采购人员采购电脑 System.out.println("------采购人员采购电脑--------"); Purchase purchase = new Purchase(); purchase.buyIBMcomputer(100); //销售人员销售电脑 System.out.println("\n------销售人员销售电脑--------"); Sale sale = new Sale(); sale.sellIBMComputer(600); //库房管理人员管理库存 System.out.println("\n------库房管理人员清库处理--------"); Stock stock = new Stock(); stock.clearStock(); } } #### 运行结果 #### ------采购人员采购电脑-------- IBM电脑的销售情况为:51 采购IBM电脑:50台 库存数量为:150 ------销售人员销售电脑-------- IBM电脑的销售情况为:51 采购IBM电脑:500台 库存数量为:650 IBM电脑的销售情况为:51 采购IBM电脑:500台 库存数量为:1150 销售IBM电脑1000台 库存数量为:150 ------库房管理人员清库处理-------- 清理存货数量为:150 折价销售IBM电脑150台 不再采购IBM电脑 但是这个造就了很高的偶合度,这并不是我们所希望的,我们所希望得解耦合 耦合性越大,要想修改一个就得修改一片,这不是面向对象设计所期望的 如果我们的管理部门多了怎么办,那显然这样是不合适的 所以我们需要一个中介者,来作为这三个部门的交流核心 #### 虚拟中介者类 #### public abstract class AbstractMediator { protected NewPurchase purchase; protected NewSale sale; protected NewStock stock; //构造函数 public AbstractMediator() { purchase = new NewPurchase(this); sale = new NewSale(this); stock = new NewStock(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 + "台"); } } //销售电脑 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电脑" + 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; } } -------------------- public class NewPurchase extends AbstractColleague { public NewPurchase(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 NewStock extends AbstractColleague { public NewStock(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 NewSale extends AbstractColleague { public NewSale(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 NewClient \{ public static void main(String[] args) { AbstractMediator mediator = new Mediator(); //采购人员采购电脑 System.out.println("------采购人员采购电脑--------"); NewPurchase purchase = new NewPurchase(mediator); purchase.buyIBMcomputer(100); //销售人员销售电脑 System.out.println("\n------销售人员销售电脑--------"); NewSale sale = new NewSale(mediator); sale.sellIBMComputer(1000); //库房管理人员管理库存 System.out.println("\n------库房管理人员清库处理--------"); NewStock stock = new NewStock(mediator); stock.clearStock(); } \} -------------------- #### 中介者模式的优点 #### 中介者模式的优点就是减少类间的依赖,把原有的一对多的依赖变成了一对一的依赖,同事类只依赖中介者,减少了依赖,当然同时也降低了类间的耦合 #### 中介者模式的缺点 #### 中介者模式的缺点就是中介者会膨胀得很大,而且逻辑复杂,原本N个对象直接的相互依赖关系转换为中介者和同事类的依赖关系,同事类越多,中介者的逻辑就越复杂 #### 中介者模式的使用场景 #### 中介者模式适用于多个对象之间紧密耦合的情况,紧密耦合的标准是:在类图中出现了蜘蛛网状结构。在这种情况下一定要考虑使用中介者模式,这有利于把蜘蛛网梳理为星型结构,使原本复杂混乱的关系变得清晰简单
相关 java 中介者模式_java中介者模式 中介者模式也是用来降低类类之间的耦合的,因为如果类类之间有依赖关系的话,不利于功能的拓展和维护,因为只要修改一个对象,其它关联的对象都得进行修改。如果使用中介者模式,只需关心和 小咪咪/ 2022年11月06日 10:50/ 0 赞/ 177 阅读
相关 中介者模式 一、什么是中介者模式 Mediator模式也叫中介者模式,是由GoF提出的23种软件设计模式的一种。Mediator模式是行为模式之一,在Mediat 小鱼儿/ 2022年07月28日 09:00/ 0 赞/ 33 阅读
相关 中介者模式 中介者模式 一、概述 1. 如果一个系统中对象之间的联系呈现为网状结构,对象之间存在大量多对多关系,将导致关系极其复杂,这些对象称为同事对象 2. 我们可以引入 曾经终败给现在/ 2022年04月18日 06:29/ 0 赞/ 215 阅读
相关 中介者模式 > 中介者模式适用于,完成一件事情,需要多方面协同合作,而多方面之间的耦合性较紧密 有一个场景 采购部门要采购IBM的电脑,它根据以下两个要素来决定采购数量。 销售 Love The Way You Lie/ 2022年03月14日 15:42/ 0 赞/ 250 阅读
相关 中介者模式 ![1365950-20190529141650092-1838345438.png][] / 中介者模式:中介在生活中是很常见的,如房屋中介,使用了中介 柔光的暖阳◎/ 2021年12月21日 12:25/ 0 赞/ 258 阅读
相关 中介者模式 中介者模式:调停者模式 定义:用一个中介对象来封装一系列的对象交互,中介者使各对象不需要相互引用,从而使其耦合松散,还可以独立地改变它们之间的交互。 中介者的职责:中转作用 不念不忘少年蓝@/ 2021年12月17日 13:55/ 0 赞/ 212 阅读
相关 中介者模式 一、前言 中介模式(Mediator),用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式的相互引用,从而使其耦合松散,而且可以独立地改变他们之间的交互。 妖狐艹你老母/ 2021年12月09日 00:53/ 0 赞/ 233 阅读
相关 中介者模式 中介者模式:用一个对象来封装一系列对象的交互。中介者使各对象不需要显示的相互引用,从而使得耦合松散,而且可以独立的改变他们之间的交互。 主要解决:对象与对象之间存在大量的关联 ゞ 浴缸里的玫瑰/ 2021年09月17日 04:42/ 0 赞/ 261 阅读
相关 中介者模式 22.中介者模式 public abstract class AbstractCardPartner// 抽象牌友类 { 分手后的思念是犯贱/ 2021年09月17日 00:08/ 0 赞/ 314 阅读
相关 中介者模式 一 点睛 一般来说,同事类之间的关系是比较复杂的,多个同事类之间互相关联时,他们之间的关系会呈现为复杂的网状结构,这是一种过度耦合的架构,即不利于类的复用,也不稳定。例如 悠悠/ 2021年07月24日 21:38/ 0 赞/ 376 阅读
还没有评论,来说两句吧...