使用策略模式(strategy pattern)实现多关键字排序(3)

(2)对于按多个关键字进行排序的情况,如果一个具体策略被使用一次,那么通常使用匿名类来声明和实例化这个具体策略,在需要进行排序的集合或数组中实现,如:

         ……

    ArrayList<EmployeeGradeRecord> aList= new ArrayList<EmployeeGradeRecord>();

         ……

 

       Collections.sort(aList, newComparator<EmployeeGradeRecord>()

       {

           public int compare(EmployeeGradeRecord Obj1,EmployeeGradeRecord Obj2)

           {

                                     //按总分数,降序排序

                return (int)(Obj2.getGradeSum()- Obj1.getGradeSum());

           }

       });

 

(3)如果一个具体策略需要被到处去以便重复使用,可以先定义一个实现具体策略的类,如:

import java.util.Comparator;

 

public class TotalGradeComparator implementsComparator<EmployeeGradeRecord>

{

    public intcompare(EmployeeGradeRecord Obj1, EmployeeGradeRecord Obj2)

    {

                   //按总分数,降序排序

        return (int)(Obj2.getGradeSum()- Obj1.getGradeSum());

    }

}

然后,在需要排序的集合或者数组中,按照指定的具体策略进行排序,如:

Collections.sort(aList,new TotalGradeComparator());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值