当前位置: 首页 > news >正文

【设计模式-02】Strategy策略模式及应用场景

一、参考资料

  • Java 官方文档

Overview (Java SE 18 & JDK 18)module indexicon-default.png?t=N7T8https://docs.oracle.com/en/java/javase/18/docs/api/index.html

  • Java中使用到的策略模式

Comparator、comparable

Comparator (Java SE 18 & JDK 18)declaration: module: java.base, package: java.util, interface: Comparatoricon-default.png?t=N7T8https://docs.oracle.com/en/java/javase/18/docs/api/java.base/java/util/Comparator.html

Comparable (Java SE 18 & JDK 18)declaration: module: java.base, package: java.lang, interface: Comparableicon-default.png?t=N7T8https://docs.oracle.com/en/java/javase/18/docs/api/java.base/java/lang/Comparable.html

二、主要设计思想

对更改关闭,对扩展开放,程序更有弹性,可扩展性强。

Extensibility、Scalability

三、应用场景

对任意数据类型的数组进行排序,如对int、double、float以及对象的排序。

1、Cat.java 对象

/*** @description: 猫对象* @author: flygo* @time: 2022/7/4 11:11*/
public class Cat {private int height, weight;public Cat() {}public Cat(int weight, int height) {this.weight = weight;this.height = height;}public int compareTo(Cat c) {if (this.weight < c.weight) return -1;else if (this.weight > c.weight) return 1;else return 0;}@Overridepublic String toString() {return "Cat{" + "height=" + height + ", weight=" + weight + '}';}
}

2、Sorter.java 排序类

/*** @description: 排序对象* @author: flygo* @time: 2022/7/4 11:16*/
public class Sorter {public void sort(Cat[] arr) {for (int i = 0; i < arr.length - 1; i++) {int minPos = i;for (int j = i + 1; j < arr.length; j++) {minPos = arr[j].compareTo(arr[minPos]) == -1 ? j : minPos;}swap(arr, i, minPos);}}static void swap(Cat[] arr, int i, int j) {Cat temp = arr[i];arr[i] = arr[j];arr[j] = temp;}
}

3、StrategyMain 主类

import java.util.Arrays;/*** @description: 主方法* @author: flygo* @time: 2022/7/4 11:15*/
public class StrategyMain {public static void main(String[] args) {//    int[] arr = {2, 4, 3, 6, 10, 1};Cat[] arr = {new Cat(3, 3), new Cat(5, 5), new Cat(1, 1)};Sorter sorter = new Sorter();sorter.sort(arr);System.out.println(Arrays.toString(arr));}
}

四、使用泛型调整修改

1、定义Comparable接口

注意接口中使用了泛型 <T>,定义了compareTo接口方法。

/*** @description: 比较接口类* @author: flygo* @time: 2022/7/4 15:46*/
public interface Comparable<T> {int compareTo(T o);
}

2、Sorter 排序类

使用Comparable 接口类承接对象数组,只要实现了Comparable接口中compareTo方法,都可以进行排序。

/*** @description: 排序对象* @author: flygo* @time: 2022/7/4 11:16*/
public class Sorter {public void sort(Comparable[] arr) {for (int i = 0; i < arr.length - 1; i++) {int minPos = i;for (int j = i + 1; j < arr.length; j++) {minPos = arr[j].compareTo(arr[minPos]) == -1 ? j : minPos;}swap(arr, i, minPos);}}static void swap(Comparable[] arr, int i, int j) {Comparable temp = arr[i];arr[i] = arr[j];arr[j] = temp;}
}

3、定义一个需要排序的对象,如Dog

Dog对象实现 Comparable 接口类中的 compareTo 方法

/*** @description: 狗* @author: flygo* @time: 2022/7/4 15:48*/
public class Dog implements Comparable<Dog> {int food;public Dog(int food) {this.food = food;}@Overridepublic int compareTo(Dog o) {if (this.food < o.food) return -1;else if (this.food > o.food) return 1;else return 0;}@Overridepublic String toString() {return "Dog{" + "food=" + food + '}';}
}

4、最终效果

最终可以实现对实现Comparable 接口compareTo方法的任意对象进行排序

import java.util.Arrays;/*** @description: 主方法* @author: flygo* @time: 2022/7/4 11:15*/
public class StrategyMain {public static void main(String[] args) {//    int[] arr = {2, 4, 3, 6, 10, 1};//    Cat[] arr = {new Cat(3, 3), new Cat(5, 5), new Cat(1, 1)};Dog[] arr = {new Dog(5), new Dog(1), new Dog(3)};Sorter sorter = new Sorter();sorter.sort(arr);System.out.println(Arrays.toString(arr));}
}

五、源码地址

GitHub - jxaufang168/Design-Patterns: 设计模式学习设计模式学习. Contribute to jxaufang168/Design-Patterns development by creating an account on GitHub.icon-default.png?t=N7T8https://github.com/jxaufang168/Design-Patterns



 

http://www.lryc.cn/news/279855.html

相关文章:

  • ssh远程登陆
  • go如何终止多个for select循环嵌套
  • nginx(1.13.7)首次安装出现:【make: *** 没有规则可以创建“default”需要的目标“build” 问题】解决措施
  • 2024.1.8 关于 Redis 数据类型 Zset 集合命令、编码方式、应用场景
  • ffmpeg[学习(四)](代码实现) 实现音频数据解码并且用SDL播放
  • C++ 字符串哈希 || 字符串前缀哈希法
  • 【java】项目部署liunx服务器的简单步骤
  • 深度学习笔记(五)——网络优化(1):学习率自调整、激活函数、损失函数、正则化
  • 鸿蒙开发现在就业前景怎样?
  • 试用统信服务器操作系统UOS 20
  • [情商-11]:人际交流的心理架构与需求层次模型
  • 【.NET Core】Lazy<T> 实现延迟加载详解
  • 坑记(HttpInputMessage)
  • day04打卡
  • 语义分割miou指标计算详解
  • Unity3d 实现直播功能(无需sdk接入)
  • 计算机缺失msvcr100.dll如何修复?分享五种实测靠谱的方法
  • 面试宝典进阶之redis缓存面试题
  • 调试(c语言)
  • opencv-4.8.0编译及使用
  • Jmeter 性能-监控服务器
  • Excel学习
  • 【技能---labelme软件的安装及其使用--ubuntu】
  • 回归预测 | Matlab实现SSA-CNN-LSTM-Attention麻雀优化卷积长短期记忆神经网络注意力机制多变量回归预测(SE注意力机制)
  • css垂直水平居中的几种实现方式
  • OpenHarmony之hdc
  • 【爬虫实战】-爬取微博之夜盛典评论,爬取了1.7w条数据
  • CST2024的License服务成功启动,仍报错——“The desired daemon is down...”,适用于任何版本!基础设置遗漏!
  • matlab中any()函数用法
  • Apache ECharts | 一个数据可视化图表库