java中排序实现简单的策略模式

策略模式(Strategy Pattern)中体现了两个非常基本的面向对象设计的原则
–封装变化的概念
–编程中使用接口,而不是对接口的实现

策略模式的定义
–定义一组算法,将每个算法都封装起来,并且使它们之间可以互换。
–策略模式使这些算法在客户端调用它们的时候能够互不影响地变化

策略模式的编写步骤
–1.对策略对象定义一个公共接口。
–2.编写策略类,该类实现了上面的公共接口
–3.在使用策略对象的类中保存一个对策略对
象的引用。
–4.在使用策略对象的类中,实现对策略对象
的set和get方法(注入)或者使用构造方法完

成赋值


java排序策略模式实现:

有这样一个类:

public class Person {

private int id;

private String name;

private int age;

}

要求:假如有若干个类Person对象存在一个List当中,对他们进行排序,分别按照名字、

年龄、id 进行排序(要有正序与倒序两种排序方式)。假如年龄或者姓名重复,按照id的正序进行排序。

以下为实现源代码。

类Person

package com.jack.SortStrategy;

public class Person {
	private int id;
	private String name;
	private int age;
	
	public Person(int id,String name,int age){
		this.id=id;
		this.age=age;
		this.name=name;
	}
	/**
	 * @return the id
	 */
	public int getId() {
		return id;
	}
	/**
	 * @param id the id to set
	 */
	public void setId(int id) {
		this.id = id;
	}
	/**
	 * @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;
	}
}

类IdOrder

package com.jack.SortStrategy;

import java.util.Comparator;

public class IdOrder implements Comparator<Person> {

	@Override
	public int compare(Person o1, Person o2) {
		// TODO Auto-generated method stub
		return o1.getId()-o2.getId();
	}
	public String getMethodName()
	{
		return "按id正序";
	}

}

类IdReverseOrder

package com.jack.SortStrategy;

import java.util.Comparator;

public class IdReverseOrder implements Comparator<Person> {
	
	@Override
	public int compare(Person o1, Person o2) {
		// TODO Auto-generated method stub
		return o2.getId()-o1.getId();
	}
	public String getMethodName()
	{
		return "按id逆序";
	}
}

类AgeOrder

package com.jack.SortStrategy;

import java.util.Comparator;

public class AgeOrder implements Comparator<Person> {


	@Override
	public int compare(Person o1, Person o2) {
		// TODO Auto-generated method stub
		int result=o1.getAge()-(o2.getAge());
		if(0==result){                                      //若年龄相同按id排
			return o1.getId()-o2.getId();
		}
		return result;
	}
	public String getMethodName()
	{
		return "按年龄正序";
	}
}

类AgeReverseOrder

package com.jack.SortStrategy;

import java.util.Comparator;

public class AgeReverseOrder implements Comparator<Person> {
	
	@Override
	public int compare(Person o1, Person o2) {
		// TODO Auto-generated method stub
		int result=o2.getAge()-(o1.getAge());
		if(0==result){                                      //若年龄相同按id排
			return o1.getId()-o2.getId();
		}
		return result;
	}
	public String getMethodName()
	{
		return "按年龄逆序";
	}
}

NameOrder

package com.jack.SortStrategy;

import java.util.Comparator;

public class NameOrder implements Comparator<Person> {

	@Override
	public int compare(Person o1, Person o2) {
		// TODO Auto-generated method stub
		int result=o1.getName().compareTo(o2.getName());
		if(0==result){                                                              //若姓名相同按id排
			return o1.getId()-o2.getId();
		}
		return result;
	}
	public String getMethodName()
	{
		return "按姓名正序";
	}
}

类NameReverseOrder

package com.jack.SortStrategy;

import java.util.Comparator;

public class NameReverseOrder implements Comparator<Person> {
	@Override
	public int compare(Person o1, Person o2) {
		// TODO Auto-generated method stub
		int result=o2.getName().compareTo(o1.getName());
		if(0==result){                                                              //若姓名相同按id排
			return o1.getId()-o2.getId();
		}
		return result;
	}
	public String getMethodName()
	{
		return "按姓名逆序";
	}
}

类Client

package com.jack.SortStrategy;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;

public class Client {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ArrayList<Person> personList = new ArrayList<Person>();
		personList.add(new Person(1, "zhangsan", 20));
		personList.add(new Person(2, "lisi", 21));
		personList.add(new Person(3, "wangwu", 25));
		personList.add(new Person(4, "zhaoliu", 26));
		personList.add(new Person(5, "chenqi", 28));
		personList.add(new Person(6, "dongba", 10));
		personList.add(new Person(7, "zhansan", 15));
		personList.add(new Person(8, "liujiu", 26));

		
		/*
		 * 可通过这里new不同的Comparator的实现从而实现不同的排序策略
		 * 分别有
		 *  IdOrder:按Id正序
		 * 	IdReverseOrder:按Id逆序
		 * NameOrder:按姓名正序
		 * NameReverseOrder:按姓名逆序
		 * AgeOrder:按年龄正序
		 * AgeReverseOrder:按年龄逆序
		 */
		Comparator<Person> comp = new IdOrder();                        

		Collections.sort(personList, comp);

		System.out.println(((IdOrder)comp).getMethodName()+"  排序后的序列是:");
		
		System.out.println("-----------------------");

		for (Iterator<Person> itor=personList.iterator();itor.hasNext();) {
			
			Person p=itor.next();
			System.out.println(p.getId() + "  " +p.getName()+ "  " + p.getAge());
		}

	}

}

执行Client可以得到排序的结果

转载于:https://my.oschina.net/jack230230/blog/37935

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值