资讯专栏INFORMATION COLUMN

设计模式之中介者模式

jackwang / 2426人阅读

摘要:中介者模式的应用中介者模式的优点就是减少类间的依赖,将一对多的依赖变成一对一的依赖,降低耦合,符合迪米特法则。中介者模式适用于多个对象之间出现紧密联系,类图成网状结构,使用中介者模式可以梳理为星型结构,有助于理解其关系。

前言

由于最近疯狂加班,博客都停更许久,难过~.~

中介者模式定义

</>复制代码

  1. 用一个中介对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使其耦合松散,而且可以独立地改变他们之间的交互。
uml类图

代码分析

我们来模仿一个进销存系统,主要有三个部分,销售、库存和进货。

</>复制代码

  1. /**
  2. * 采购管理,主要负责是否采购糖果
  3. */
  4. public class CandyPurchase {
  5. public void buyCandy(int number){
  6. CandySale candySale = new CandySale();
  7. CandyStock candyStock = new CandyStock();
  8. if (candySale.getSaleStauts()>6){
  9. candyStock.addStock(number);
  10. System.out.println("采购糖果"+number+"颗");
  11. }else {
  12. candyStock.addStock(number/2);
  13. System.out.println("采购糖果"+number/2+"颗");
  14. }
  15. System.out.println("库存"+CandyStock.stockNum+"颗");
  16. }
  17. public void refuseBuyCandy(){
  18. System.out.println("拒绝进货");
  19. }
  20. }

</>复制代码

  1. /**
  2. * 销售类:
  3. */
  4. public class CandySale {
  5. public void saleCandy(int num){
  6. while (CandyStock.stockNum
  7. </>复制代码

    1. //库存
    2. public class CandyStock {
    3. //库存数量
    4. protected static int stockNum =1000;
    5. public synchronized void addStock(int num){
    6. stockNum+=num;
    7. }
    8. public synchronized void subtractStock(int num){
    9. stockNum-=num;
    10. }
    11. public void clearStock(){
    12. System.out.println("马上年底了,清仓大甩卖了");
    13. CandyPurchase candyPurchase = new CandyPurchase();
    14. candyPurchase.refuseBuyCandy();
    15. CandySale candySale = new CandySale();
    16. candySale.discountSale();
    17. }
    18. }
  8. </>复制代码

    1. public class Client {
    2. public static void main(String[] args) {
    3. System.out.println("-----采购糖果-----");
    4. CandyPurchase candyPurchase = new CandyPurchase();
    5. candyPurchase.buyCandy(666);
    6. System.out.println("-----销售糖果-----");
    7. CandySale candySale = new CandySale();
    8. candySale.saleCandy(20);
    9. System.out.println("-----清库处理-----");
    10. CandyStock candyStock = new CandyStock();
    11. candyStock.clearStock();
    12. }
    13. }
    14. 测试结果:
    15. -----采购糖果-----
    16. 采购糖果666颗
    17. 库存1666颗
    18. -----销售糖果-----
    19. 卖出20颗糖
    20. -----清库处理-----
    21. 马上年底了,清仓大甩卖了
    22. 拒绝进货
    23. 打折销售糖果1646颗
  9. 结果和我们预期的一致,但我们这三者是彼此关联的,每个类都与其他两个类发生了关系(纯洁点,不要想歪~,~)。迪米特法则认为每个类应只和朋友类交流,而且朋友类并非越多越好,朋友类越多,耦合性越大,修改一个就要从全局考量是否影响到了其他模块,这不是面向对象设计所期望的。让我们用中介者模式把其优化下吧,代码如下:

  10. </>复制代码

    1. public abstract class AbstractCandyMediator {
    2. protected CandyStock candyStock;
    3. protected CandySale candySale;
    4. protected CandyPurchase candyPurchase;
    5. public AbstractCandyMediator() {
    6. this.candyStock = new CandyStock(this);
    7. this.candySale = new CandySale(this);
    8. this.candyPurchase = new CandyPurchase(this);
    9. }
    10. public abstract void execute(String type,Object ...objects);
    11. }
  11. </>复制代码

    1. public class ConcreteCandyMediator extends AbstractCandyMediator{
    2. @Override
    3. public void execute(String type, Object... objects) {
    4. if (type.equals("buyCandy")){
    5. this.buyCandy((Integer) objects[0]);
    6. }else if (type.equals("saleCandy")){
    7. this.saleCandy((Integer) objects[0]);
    8. }else {
    9. this.clearStock();
    10. }
    11. }
    12. private void buyCandy(int num) {
    13. if (super.candySale.getSaleStauts()>6){
    14. super.candyStock.addStock(num);
    15. System.out.println("采购糖果"+ num+"颗");
    16. }else {
    17. super.candyStock.addStock(num/2);
    18. System.out.println("采购糖果"+num /2+"颗");
    19. }
    20. System.out.println("库存"+CandyStock.stockNum+"颗");
    21. }
    22. public void saleCandy(int num){
    23. while (CandyStock.stockNum
    24. </>复制代码

      1. public abstract class AbstractColleague {
      2. public AbstractCandyMediator mediator;
      3. public AbstractColleague(AbstractCandyMediator mediator) {
      4. this.mediator = mediator;
      5. }
      6. }
    25. </>复制代码

      1. public class CandyPurchase extends AbstractColleague {
      2. public CandyPurchase(AbstractCandyMediator abstractCandyMediator) {
      3. super(abstractCandyMediator);
      4. }
      5. public void buyCandy(int number){
      6. super.mediator.execute("buyCandy",number);
      7. }
      8. public void refuseBuyCandy(){
      9. System.out.println("拒绝进货");
      10. }
      11. }
    26. </>复制代码

      1. public class CandySale extends AbstractColleague {
      2. public CandySale(AbstractCandyMediator abstractCandyMediator) {
      3. super(abstractCandyMediator);
      4. }
      5. public void saleCandy(int num){
      6. super.mediator.execute("saleCandy",num);
      7. }
      8. //打折销售
      9. public void discountSale(){
      10. System.out.println("打折销售糖果"+CandyStock.stockNum+"颗");
      11. }
      12. //获得最近的销售状态,0-10,越大越好卖
      13. public int getSaleStauts(){
      14. Random random = new Random();
      15. return random.nextInt(10);
      16. }
      17. }
    27. </>复制代码

      1. public class CandyStock extends AbstractColleague{
      2. //库存数量
      3. protected static int stockNum =1000;
      4. public CandyStock(AbstractCandyMediator abstractCandyMediator) {
      5. super(abstractCandyMediator);
      6. }
      7. public synchronized void addStock(int num){
      8. stockNum+=num;
      9. }
      10. public synchronized void subtractStock(int num){
      11. stockNum-=num;
      12. }
      13. public void clearStock(){
      14. super.mediator.execute("123");
      15. }
      16. }
    28. </>复制代码

      1. public class Client {
      2. public static void main(String[] args) {
      3. AbstractCandyMediator mediator = new ConcreteCandyMediator();
      4. CandyPurchase candyPurchase = new CandyPurchase(mediator);
      5. candyPurchase.buyCandy(666);
      6. CandySale candySale = new CandySale(mediator);
      7. candySale.saleCandy(20);
      8. CandyStock candyStock = new CandyStock(mediator);
      9. candyStock.clearStock();
      10. }
      11. }
    29. 经过改造,我们发现每个类都只与中介者是朋友类,耦合降低,每个类只处理自己的职责,和其他类有关的统统交给中介者。

    30. 中介者模式的应用
    31. 中介者模式的优点就是减少类间的依赖,将一对多的依赖变成一对一的依赖,降低耦合,符合迪米特法则。缺点就是中介者会变得异常庞大,逻辑复杂,同事类越多,中介者的逻辑就越复杂。中介者模式适用于多个对象之间出现紧密联系,类图成网状结构,使用中介者模式可以梳理为星型结构,有助于理解其关系。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/68200.html

相关文章

  • 实用模式介者模式

    摘要:好,师傅我们要学习帝吧人民,进能打,退能刷淘宝。恩,大致过程就是这样,我们使用中介者模式想一想。首先,数据需要放在中介者模式内,用户的一切操作,都会传递给中介者模式,由他来选择是哪一个部分发生改变。 俗话说,一个模式三个坑。 中介者模式应该算最坑的一个模式,坑不在于他的原理。而在于他的名字和其他模式的使用,真尼玛像。首先,中介者 好像是一切模式里面都有的一个东西,比如,享元模式中-元对...

    AlexTuan 评论0 收藏0
  • 设计模式介者模式

    摘要:用中介者模式实现土豆馒头豆包地瓜土豆馒头豆包地瓜土豆馒头输出缺陷使用中介者模式可以很大程度上避免对象之间的相互影响,无论是对于代码的可读性以及逻辑性都可以简化。 中介者模式 我们知道在程序中各个对象之间并不是完全独立的,相互之间是可能存在关系的,并且可能会相互影响的,就像这样。 showImg(https://segmentfault.com/img/bVJ8wK?w=428&h=51...

    shixinzhang 评论0 收藏0
  • javascript介者模式

    摘要:中介者模式中介者模式对象和对象之间借助第三方中介者进行通信。将就用下这个这个函数充当中介者挑戰成功挑战失败选手选手选手选手挑战成功选手挑战成功选手挑战失败在这段代码中之间没有直接发生关系而是通过另外的对象建立链接姑且将之当成是中介者模式了。 中介者模式 中介者模式: 对象和对象之间借助第三方中介者进行通信。 showImg(https://segmentfault.com/img/bV...

    LucasTwilight 评论0 收藏0
  • 一起学设计模式 - 介者模式

    摘要:在地球上最大的中介者就是联合国了,它主要用来维护国际和平与安全解决国际间经济社会文化和人道主义性质的问题。所以对于关系比较复杂的系统,我们为了减少对象之间的关联关系,使之成为一个松耦合系统,我们就需要使用中介者模式。 中介者模式(Mediator Pattern)属于行为型模式的一种,用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独...

    denson 评论0 收藏0
  • 忘了再看设计模式-行为型

    摘要:推文用设计模式解构三国是一种什么体验行为型设计模式一策略模式工厂模式优化结构状态模式随着状态改变而改变行为。推文状态机与状态模式责任链模式多个对象依次处理请求前者指定后者。代理模式代理针对一个对象,为了增加控制等中介双方都是多个,为了解耦。 策略模式 选择使用封装好的一系列算法,可相互替换。 类比:商店[Context]买完衣服买单[Stratege](现金[Concrete Stra...

    ShevaKuilin 评论0 收藏0

发表评论

0条评论

jackwang

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<