欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 资讯 > 策略模式介绍和代码示例

策略模式介绍和代码示例

2025/4/3 19:40:40 来源:https://blog.csdn.net/Fu_Cong/article/details/145772141  浏览:    关键词:策略模式介绍和代码示例

策略模式(Strategy Pattern)是一种行为设计模式,它定义了一系列算法,并将每一个算法封装起来,使它们可以互换,算法的变化不会影响到使用算法的客户。策略模式让算法独立于其使用者,并且可以根据需要切换算法。

策略模式的关键要素:

  1. 策略接口(Strategy Interface):定义算法的公共接口。
  2. 具体策略类(Concrete Strategy):实现策略接口的具体算法类。
  3. 上下文(Context):使用策略接口来配置和管理具体策略对象。

示例代码:

假设我们有一个简单的排序算法,我们想要根据不同的排序策略(如冒泡排序、选择排序)来排序一个数组。

首先,我们定义一个排序策略接口:

public interface SortingStrategy {void sort(int[] array);
}

然后,我们创建两个具体的排序策略类,实现上述接口:

public class BubbleSortStrategy implements SortingStrategy {public void sort(int[] array) {// 冒泡排序算法实现}
}
public class SelectionSortStrategy implements SortingStrategy {public void sort(int[] array) {// 选择排序算法实现}
}

接下来,我们创建一个上下文类,它将使用具体的排序策略:

public class SortContext {private SortingStrategy strategy;public SortContext(SortingStrategy strategy) {this.strategy = strategy;}public void setStrategy(SortingStrategy strategy) {this.strategy = strategy;}public void executeSort(int[] array) {strategy.sort(array);}
}

最后,我们可以在客户端代码中根据需要切换不同的排序策略:

public class StrategyPatternDemo {public static void main(String[] args) {int[] numbers = { 5, 1, 4, 2, 8 };SortContext context = new SortContext(new BubbleSortStrategy());context.executeSort(numbers);System.out.println("Sorted array with Bubble Sort: " + Arrays.toString(numbers));// 切换到选择排序策略context.setStrategy(new SelectionSortStrategy());context.executeSort(numbers);System.out.println("Sorted array with Selection Sort: " + Arrays.toString(numbers));}
}

在这个示例中,SortContext是上下文,它依赖于SortingStrategy接口。BubbleSortStrategySelectionSortStrategy是具体的策略实现。客户端代码通过SortContext来使用不同的排序策略,而不需要知道具体的排序细节。这样,算法的变化不会影响客户端代码,符合开闭原则(对扩展开放,对修改封闭)。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词