随笔- 79  文章- 1  评论- 1  阅读- 1678 

概述

策略模式 (Strategy Pattern) 又称 Policy,它定义并封装每一种算法,这些算法可以相互替换。

优点:符合开闭原则。
缺点:需要知道并理解每个算法才能选择合适的算法。

interface Sort {
  abstract void sort(int[] a);
}

class BubbleSort implements Sort {
  public void sort(int[] a) {
    // 冒泡算法的具体实现
  }
}

class InsertSort implements Sort {
  public void sort(int[] a) {
    int len = a.length;
    for (int i = 0; i < len; i++) {
      int j;
      int temp = a[i];
      for (j = i; j > 0; j--) {
        if (a[j - 1] > temp) {
          a[j] = a[j - 1];
        }
      }
      if (j != i) {
        a[j] = temp;
      }
    }
  }
}

class Context {
  private Sort s;
  
  public void sort(int[] a) {
    s.sort(a);
  }
  
  public void setSort(Sort s) {
    this.s = s;
  }
}

图示:
image

参考

[1] 刘伟,设计模式,2011.

 posted on   x-yun  阅读(5)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示