JAVA与设计模式--之STRATEGY策略模式

     策略模式针对一组算法,将每一个算法封装到具有共同接口的独立的类中,从而使得它们可以相互替换。
策略模式使得算法可以在不影响到客户端的情况下发生变化。策略模式把行为和环境分开。环境类负责维持
和查询行为类,各种算法在具体的策略类中提供。由于算法和环境独立开来,算法的增减,修改都不会影响
到环境和客户端。
    其实在我们做对象排序时,就会用到这一策略模式。比如,需要对ArrayList中的Person对象按照年龄排序,
而Person对象本身就没有支持自比较(也就是没有而没有实现Comparable接口),在不修改Person的前提下,
可以通过Comparator接口来实现比较算法进行排序。Mycomparator就是实现了Comparator接口的类,我们的
排序算法都封装在这个类里面,在这个类里可以实现不同的排序算法,比如:升序、降序等。这个时候我们的算法
(Mycomparator)和数据(Person)都分离开来。

 

Person.java类:

package arraylistsort; /** * Person类 * */ public class Person { /** * 姓名 */ private String name = ""; /** * 年龄 */ private int age = 0; /** * 构造函数 */ public Person(String name,int age){ this.name = name; this.age = age; } /** * @return the name */ public String getName() { return name; } /** * @param name the name to set */ public void setName(String name) { this.name = name; } /** * @return the age */ public int getAge() { return age; } /** * @param age the age to set */ public void setAge(int age) { this.age = age; } }

 

 

Mycomparator.java类

package arraylistsort; import java.util.Comparator; /*Comparator,Comparable的区别 (1)comparable是通用的接口,用户可以实现它来完成自己特定的比较,而comparator可以看成一种算法的实现,在需要容器集合 collection需要比较功能的时候,来指定这个比较器,这可以看出一种设计模式,将算法和数据分离,就像C++ STL中的函数对象一样。   (2)comparable应该比较固定,和一个具体类相绑定,而Comparator比较灵活,它可以被用于各个需要比较功能的类使用。可以说前者属于“静态绑定”,而后者可以“动态绑定”。   (3)一个类实现了Camparable接口表明这个类的对象之间是可以相互比较的。如果用数学语言描述的话就是这个类的对象组成的集合中存在一个全序。这样,这个类对象组成的集合就可以使用Sort方法排序了。 (4)Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作)   而 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。   可以说一个是自已完成比较,一个是外部程序实现比较的差别而已。   用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。 (5)Comparator的作用有两个:    1. 如果类的设计师没有考虑到Compare的问题而没有实现Comparable接口,可以通过 Comparator来实现比较算法进行排序    2. 为了使用不同的排序标准做准备,比如:升序、降序或其他什么序*/ @SuppressWarnings("unchecked") public class Mycomparator implements Comparator<Person> { public int compare(Person p1, Person p2) { return (p1.getAge() - p2.getAge());//升序 //return (p2.getAge() - p1.getAge());//降序 } }

 

ArrayListSort.java测试类

package arraylistsort; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.Iterator; import java.util.List; public class ArrayListSort { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub List<Person> list = new ArrayList<Person>(); list.add(new Person("韩梅梅",26)); list.add(new Person("李雷",27)); list.add(new Person("Lucy",25)); list.add(new Person("吉姆",28)); list.add(new Person("Lily",24)); Comparator<Person> comp = new Mycomparator(); Collections.sort(list,comp); Iterator<Person> it = list.iterator(); while(it.hasNext()){ Person p = it.next(); System.out.println(p.getName() + ":" + p.getAge()); } } }

 

运行结果:

Lily:24
Lucy:25
韩梅梅:26
李雷:27
吉姆:28

 

你可能感兴趣的:(JAVA与设计模式--之STRATEGY策略模式)