【设计模式】策略模式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
相关文章
|
3月前
|
设计模式 算法
策略模式-大话设计模式
策略模式-大话设计模式
|
2天前
|
设计模式 运维 算法
Java设计模式-策略模式(15)
Java设计模式-策略模式(15)
|
9天前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深度解析
在PHP开发中,策略模式是一种行为设计模式,它允许你在运行时根据不同情况选择不同的算法或行为。本文将深入探讨策略模式的定义、结构、使用场景以及在PHP中的实现方法,并通过实例展示如何在PHP项目中应用策略模式来提高代码的灵活性和可维护性。
|
4月前
|
设计模式 算法 Java
Java一分钟之-设计模式:策略模式与模板方法
【5月更文挑战第17天】本文介绍了策略模式和模板方法模式,两种行为设计模式用于处理算法变化和代码复用。策略模式封装不同算法,允许客户独立于具体策略进行选择,但需注意选择复杂度和过度设计。模板方法模式定义算法骨架,延迟部分步骤给子类实现,但过度抽象或滥用继承可能导致问题。代码示例展示了两种模式的应用。根据场景选择合适模式,以保持代码清晰和可维护。
81 1
|
10天前
|
设计模式 人工智能 算法
PHP中的设计模式:策略模式的深入解析与实践软件测试中的人工智能革命:提升效率与准确性的新篇章
在PHP开发中,理解并运用设计模式是提升代码质量和可维护性的重要途径。本文聚焦于策略模式(Strategy Pattern),一种行为型设计模式,它允许在运行时选择算法或业务规则。通过本文,我们将深入探讨策略模式的定义、结构、使用场景以及如何在PHP项目中有效地实现和利用策略模式。不同于性能优化等技术性摘要,本文着重于提供对策略模式全面而实用的理解,助力开发者编写出更加灵活和可扩展的应用程序。 本文深入探讨了人工智能在软件测试领域的应用,揭示了其如何显著提高测试过程的效率和准确性。通过实际案例分析,展示了AI技术在自动化测试、缺陷检测及结果分析中的关键作用,并讨论了实施AI测试策略时面临的挑
16 3
|
14天前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深度解析
在本文中,我们将深入探讨PHP编程中的策略模式,这是一种行为型设计模式,用于定义一系列算法,将每个算法封装起来,并使它们可以互换。通过详细讲解策略模式的概念、结构以及在PHP中的实现方式,我们希望能够帮助读者更好地理解和应用这一设计模式,提升代码的灵活性和可维护性。
24 1
|
2天前
|
设计模式 存储 算法
PHP中的设计模式:策略模式的深入解析与应用在软件开发的浩瀚海洋中,PHP以其独特的魅力和强大的功能吸引了无数开发者。作为一门历史悠久且广泛应用的编程语言,PHP不仅拥有丰富的内置函数和扩展库,还支持面向对象编程(OOP),为开发者提供了灵活而强大的工具集。在PHP的众多特性中,设计模式的应用尤为引人注目,它们如同精雕细琢的宝石,镶嵌在代码的肌理之中,让程序更加优雅、高效且易于维护。今天,我们就来深入探讨PHP中使用频率颇高的一种设计模式——策略模式。
本文旨在深入探讨PHP中的策略模式,从定义到实现,再到应用场景,全面剖析其在PHP编程中的应用价值。策略模式作为一种行为型设计模式,允许在运行时根据不同情况选择不同的算法或行为,极大地提高了代码的灵活性和可维护性。通过实例分析,本文将展示如何在PHP项目中有效利用策略模式来解决实际问题,并提升代码质量。
|
29天前
|
设计模式 缓存 算法
揭秘策略模式:如何用Java设计模式轻松切换算法?
【8月更文挑战第30天】设计模式是解决软件开发中特定问题的可重用方案。其中,策略模式是一种常用的行为型模式,允许在运行时选择算法行为。它通过定义一系列可互换的算法来封装具体的实现,使算法的变化与客户端分离。例如,在电商系统中,可以通过定义 `DiscountStrategy` 接口和多种折扣策略类(如 `FidelityDiscount`、`BulkDiscount` 和 `NoDiscount`),在运行时动态切换不同的折扣逻辑。这样,`ShoppingCart` 类无需关心具体折扣计算细节,只需设置不同的策略即可实现灵活的价格计算,符合开闭原则并提高代码的可维护性和扩展性。
39 2
|
1月前
|
设计模式 算法 开发者
深入理解工厂模式与策略模式:设计模式的灵活应用
深入理解工厂模式与策略模式:设计模式的灵活应用
|
11天前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的应用与实践
在软件开发中,设计模式是解决问题的最佳实践。本文将探讨PHP中的策略模式,通过实际应用案例,展示如何有效地使用策略模式来提高代码的灵活性和可维护性。我们将从基本概念入手,逐步深入到实际编码,最终实现一个具有策略模式的应用。