java:集合的自定义多重排序
问题:
有一个乱序的对象集合,要求先按对象的属性A排序(排序规则由业务确定,非A-Z或0-9的常规顺序),相同A属性的记录,按根据属性B排序(排序规则,同样由业务确定,非常规顺序) -前提:业务规则是明确的
示例:
FSUData对象定义
package acc.test;
public class FSUData {
public FSUData(String airport, String fsuCode) {
this.airport = airport;
this.fsuCode = fsuCode;
}
/**
* 航站
*/
private String airport;
/**
* FSU状态节点
*/
private String fsuCode;
public String getAirport() {
return airport;
}
public void setAirport(String airport) {
this.airport = airport;
}
public String getFsuCode() {
return fsuCode;
}
public void setFsuCode(String fsuCode) {
this.fsuCode = fsuCode;
}
public String toString() {
return airport + "/" + fsuCode;
}
}
原始数据:
[法兰克福/RCF, 法兰克福/DLV, 成都/DEP, 成都/RCS, 上海/DEP, 上海/RCF]
业务规则:
航站排序规则:成都 -> 上海 -> 法兰克福
FSU排序规则:RCS -> RCF -> TFD -> DEP -> DLV
要求排序后变成下面这样:
[成都/RCS, 成都/DEP, 上海/RCF, 上海/DEP, 法兰克福/RCF, 法兰克福/DLV]
java代码:
package acc.test; import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.junit.Test; public class FSUSortTest { Map<String, Integer> airportDic = new HashMap<String, Integer>();
Map<String, Integer> fsuDic = new HashMap<String, Integer>(); @Test
public void test() { // 先定义顺序规则
airportDic.put("成都", 1);
airportDic.put("上海", 2);
airportDic.put("法兰克福", 3); fsuDic.put("RCS", 1);
fsuDic.put("RCF", 2);
fsuDic.put("TFD", 3);
fsuDic.put("DEP", 4);
fsuDic.put("DLV", 5); // 建一个待排序的目标"数组"
List<FSUData> target = new ArrayList<FSUData>(); target.add(new FSUData("法兰克福", "RCF"));
target.add(new FSUData("法兰克福", "DLV")); target.add(new FSUData("成都", "DEP"));
target.add(new FSUData("成都", "RCS")); target.add(new FSUData("上海", "DEP"));
target.add(new FSUData("上海", "RCF")); System.out.println("排序前:" + target); // 排序
FsuComparator fsuComparator = new FsuComparator(airportDic, fsuDic);
Collections.sort(target, fsuComparator); System.out.println("排序后:" + target);
} private class FsuComparator implements Comparator<FSUData> { Map<String, Integer> airportMap;
Map<String, Integer> fsuMap; public FsuComparator(Map<String, Integer> airportMap,
Map<String, Integer> fsuMap) {
this.airportMap = airportMap;
this.fsuMap = fsuMap;
} public int compare(FSUData s1, FSUData s2) { // 从顺序规则Map里,取出"排序值"
Integer airportOrder1 = airportMap.get(s1.getAirport());
Integer airportOrder2 = airportMap.get(s2.getAirport()); // 如果Airport相同,则比较FSUCode
if (airportOrder1 == airportOrder2) {
Integer fsuOrder1 = fsuMap.get(s1.getFsuCode());
Integer fsuOrder2 = fsuMap.get(s2.getFsuCode());
return fsuOrder1.compareTo(fsuOrder2);
} return airportOrder1.compareTo(airportOrder2);
}
} }
思路:先将"业务排序规则" 转换成 "常规有序规则",然后再利用Comparator接口实现比较
java:集合的自定义多重排序的更多相关文章
- Java,集合按自定义规则排序
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.u ...
- [c#基础]泛型集合的自定义类型排序
引用 最近总有种感觉,自己复习的进度总被项目中的问题给耽搁了,项目中遇到的问题,不总结又不行,只能将复习基础方面的东西放后再放后.一直没研究过太深奥的东西,过去一年一直在基础上打转,写代码,反编译,不 ...
- C# 泛型集合的自定义类型排序
一.泛型集合List<T>排序 经sort方法之后,采用了升序的方式进行排列的. List<int> list = new List<int>() { 2, 4, ...
- [java]三种自定义链表排序方式
代码: import java.util.ArrayList; import java.util.Comparator; import java.util.List; class Emp{ Strin ...
- Java集合框架实现自定义排序
Java集合框架针对不同的数据结构提供了多种排序的方法,虽然很多时候我们可以自己实现排序,比如数组等,但是灵活的使用JDK提供的排序方法,可以提高开发效率,而且通常JDK的实现要比自己造的轮子性能更优 ...
- JAVA集合四:比较器--类自定义排序
参考链接: HOW2J.CN 前言 对于JAVA集合,都能够用集合的工具类Collections 提供的方法: Collections.sort(List list) Collections.sort ...
- Java集合排序(面试必考点之一)
集合是Java面试必考知识点,而集合的排序也是非常重要的,工作中经常用到,那么这个知识点也是必须要掌握的,下面是我曾经面试时被面试官问的问题: 根据API可知,Java集合的工具类Collection ...
- java集合进行排序的两种方式
java集合的工具类Collections中提供了两种排序的方法,分别是: Collections.sort(List list) Collections.sort(List list,Compara ...
- Java集合框架和数组的排序(转载)
Java集合框架(*Collection)*和数组的排序 根据约定,在使用java编程的时候应尽可能的使用现有的类库,当然你也可以自己编写一个排序的方法,或者框架,但是有几个人能写得比JDK里的还 ...
随机推荐
- DNS劫持解决方法
刚在家上网,发自己的浏览器竟然还会弹出页面广告(我浏览器装了屏蔽广告的浏览器应用,理论上就不会出现什么弹出来的广告). 于是自己仔细研究了下,发现在易迅的页面竟然嵌套了一个iframe,首先易迅肯定不 ...
- php设计模式 观察者模式
观察者模式的核心是把客户元素(观察者)从一个中心类(主体)中分离开来.当主体知道事件发生时,观察者需要被通知到.同时,我们并不希望将主体与观察者之间的关系进行硬编码.为了达到这个目的,我们可以允许观察 ...
- C#复习④
C#复习④ 2016年6月16日 12:37 Main Classes and Structs 类和结构体 1.Contents of Classes 字段,常量,方法,构造函数,析构函数: 特性,事 ...
- 17、文案人员 - IT软件人员书籍系列文章
这里说的文案人员是软件项目中的一个角色.其主要负责相关文档的整理,用户使用说明书的编写等等,在项目中是一个辅助的角色. 文案人员所做的事情不错,但是她能够辅助软件配置管理工程师进行工作,更好的为维护文 ...
- spring 事务管理方式及配置
1.Spring声明式事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之前对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学习发觉Spring的 ...
- Windows系统安装Oracle 11g 数据库
一.下载 http://www.oracle.com/technetwork/database/enterprise-edition/downloads/index.html以下两网址来源此官方下载页 ...
- 使用SQL语句创建SQL数据脚本(应对万网主机部分不支持导出备份数据)
1.查询待导出表Ad中的数据. SELECT * FROM [DB_Temp].[dbo].[Ad] 2.编写存储过程. --将表数据生成SQL脚本的存储过程 CREATE PROCEDURE dbo ...
- 关于iOS构建版本提交iTunes后,一直不出现,没加号的解决方案
最近第一次遇到,正常打包,上传iTunes App Store,都能正常upload. 也可能是因为刚升了Xcode 8 的缘故,莫名其妙的小问题... 描述如下: 如果进iTunes的活动界面,也能 ...
- STM32之USART库函数USART_SendData的bug
转载自:http://www.cnblogs.com/itloverhpu/p/3250537.html 1.最近在调试ATM32F103CB时发现,一串数据的最后一个字节总是发送不出去,用的是RS4 ...
- Hadoop2.6 datanode配置在线更新
datanode 的配置可以在线更新了,http://blog.cloudera.com/blog/2015/05/new-in-cdh-5-4-how-swapping-of-hdfs-datano ...