【设计模式】策略模式Strategy_03

简介:
接着上一篇总结继续探讨。
我们之前用自己的方式来实现了JDK的Comparable和Comparator接口,我们下面来看看实际当中JDK给我们的Comparable和Comparator接口。

我们对之前的Dog和Dog的比较类DogWeightComparator的实现进行修改:
Dog.java:
package cn.edu.hpu.Strategy;

public class Dog implements java.lang.Comparable<Dog>{
	//狗的身高
	private int height;
	//狗的体重
	private int weight;
	//比较器(默认指定DogWeightComparator)
	private java.util.Comparator<Dog> comparator=new DogWeightComparator();
	
	public Dog(int height, int weight) {
		super();
		this.height = height;
		this.weight = weight;
	}
	
	public java.util.Comparator getComparator() {
		return comparator;
	}


	public void setComparator(java.util.Comparator comparator) {
		this.comparator = comparator;
	}


	public int getHeight() {
		return height;
	}
	public void setHeight(int height) {
		this.height = height;
	}
	public int getWeight() {
		return weight;
	}
	public void setWeight(int weight) {
		this.weight = weight;
	}
	@Override
	public int compareTo(Dog o) {
		return comparator.compare(this, o);
	}
	@Override
	public String toString() {
		return this.getHeight()+"|"+this.getWeight();
	}
	
	
}

DogWeightComparator.java:
package cn.edu.hpu.Strategy;


public class DogWeightComparator implements java.util.Comparator<Dog>{


	@Override
	public int compare(Dog o1, Dog o2) {
		Dog d1=(Dog)o1;
		Dog d2=(Dog)o2;
		if(d1.getWeight()>d2.getWeight()) return 1;
		else if(d1.getWeight()<d2.getWeight()) return -1;
		return 0;
	}


}

DataSorter中的类型也要改成java.lang.Comparable
DataSorter.java:
package cn.edu.hpu.Strategy;


public class DataSorter {


	public static void sort(Object[] a) {
		for (int i = a.length; i >0; i--) {
			for (int j = 0; j < i-1; j++) {
				java.lang.Comparable o1=(java.lang.Comparable)a[j];
				java.lang.Comparable o2=(java.lang.Comparable)a[j+1];
				if(o1.compareTo(o2)==1){
					swap(a,j,j+1);
				}
			}
		}
		
	}
	
	private static void swap(Object[] a, int x, int y) {
		Object temp=a[x];
		a[x]=a[y];
		a[y]=temp;
		
	}	
	
	public static void p(Object[] a) {
		for (int i = 0; i < a.length; i++) {
			System.out.print(a[i]+" ");
		}
		System.out.println();
	}


}

测试(按重量排序):
package cn.edu.hpu.Strategy;


public class Test {
	public static void main(String[] args) {
		//int[] a={9,5,3,7,1}; 


		Dog[] dogs={new Dog(3,8),new Dog(5,4),new Dog(1,2)};
		DataSorter.sort(dogs); 
		DataSorter.p(dogs);
		/*
		Cat[] cats={new Cat(21),new Cat(15),new Cat(9)};
		DataSorter.sort(cats); 
		DataSorter.p(cats);*/
	}
}

测试结果:
1|2 5|4 3|8 

我们探讨了JDK的Comparable和Comparator接口的使用,是不是和我们自己写的那个使用方法和效果完全一样(唯一区别就是JDK的接口使用了泛型,泛型的好处就是不用再强制转换了)?说明我们已经成功模拟出了JDK的Comparable和Comparator接口。

再来看,刚刚我们自己写了sort方法,其实我们也不用写这个方法,可以使用java.Util.Arrays.sort(a);进行排序,前提是只要实现了java.lang.Comparable接口即可。
测试:
package cn.edu.hpu.Strategy;


public class Test {
	public static void main(String[] args) {
		//int[] a={9,5,3,7,1}; 


		Dog[] dogs={new Dog(3,8),new Dog(5,4),new Dog(1,2)};
		java.util.Arrays.sort(dogs); 
		DataSorter.p(dogs);
	}
}
测试结果:
1|2 5|4 3|8 
是不是也可以?当然可以

为什么说数据结构和算法在日常工作中不重要了,是因为这些东西在Java中已经给大家封装的很好了,大家只需要懂得原理,巧妙的去使用他们即可。

写了这些我们发现JDK中都有,是不是白写了?不是,写完Comparable和Comparator接口,我们就学习了策略模式,深入学习了Comparable和Comparator接口的设计模式。

那么什么是策略模式?在本例中就是:当进行比较大小的时候,定义一个策略的比较器,然后由具体的比较策略来决定到底谁大谁小。

作业:
封装一下商场的打折策略
现在商场都有许多打折活动,我们的打折策略不能写死,所以我们最好把打折策略定义成一个可以拓展的策略。

作业在以后总结总解答
转载请注明出处:http://blog.csdn.net/acmman/article/details/46634607
相关文章
|
2月前
|
设计模式 算法 测试技术
PHP中的设计模式:策略模式的应用与实践
在软件开发的浩瀚海洋中,设计模式如同灯塔,指引着开发者们避开重复造轮子的暗礁,驶向高效、可维护的代码彼岸。今天,我们将聚焦于PHP领域中的一种重要设计模式——策略模式,探讨其原理、应用及最佳实践,揭示如何通过策略模式赋予PHP应用灵活多变的业务逻辑处理能力,让代码之美在策略的变换中熠熠生辉。
|
12天前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
37 2
|
1月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
本教程详细讲解Kotlin语法,适合深入学习。快速入门可参考“简洁”系列教程。本文通过游泳运动员的案例,介绍策略模式及其在Kotlin中的改良应用,利用高阶函数简化代码结构,提高灵活性。
30 3
|
1月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
本教程详细讲解Kotlin语法,适合深入学习。快速入门可参考“简洁”系列教程。本文介绍策略模式在Kotlin中的应用,通过游泳运动员的例子,展示如何使用接口和高阶函数实现策略模式,使代码更简洁、灵活。
28 2
|
1月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
62 3
|
1月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
27 3
|
1月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入解析与实践
【10月更文挑战第9天】 策略模式是一种行为设计模式,它允许在运行时选择算法的行为。在PHP开发中,通过使用策略模式,我们可以轻松切换算法或逻辑处理方式而无需修改现有代码结构。本文将深入探讨策略模式的定义、结构以及如何在PHP中实现该模式,并通过实际案例展示其应用价值和优势。
30 1
|
1月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入解析与应用
【10月更文挑战第8天】 在软件开发的浩瀚宇宙中,设计模式如同星辰指引,照亮了代码设计与架构的航道。本文旨在深入探索PHP语境下策略模式(Strategy Pattern)的精髓,不仅剖析其内核原理,还将其融入实战演练,让理论在实践中生根发芽。策略模式,作为解决“如何优雅地封装算法族”的答案,以其独特的灵活性与扩展性,赋予PHP应用以动态变换行为的能力,而无需牵动既有的类结构。
24 2
|
1月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入解析与实践
在PHP开发中,设计模式是提高代码可读性、可维护性和扩展性的重要工具。本文将深入探讨策略模式这一行为型设计模式,通过分析其定义、结构、使用场景以及在PHP中的实际应用,帮助开发者更好地理解和运用策略模式来优化自己的项目。不同于传统摘要的简洁概述,本文摘要部分将详细阐述策略模式的核心理念和在PHP中的实现方法,为读者提供清晰的指引。
|
1月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入解析与实践
策略模式是一种行为型设计模式,用于定义一系列算法,将每种算法都封装起来,并使它们可以互换。本文将探讨如何在PHP中实现策略模式,以及如何利用它来提高代码的灵活性和可维护性。通过具体示例,我们将看到策略模式在处理复杂业务逻辑时的优势,从而帮助开发者编写出更加清晰、易于扩展的代码。