对list根据自定义方法排序记要
List list = dao.findAllToMap();//得到所有数据,结果封装成List<Map>
ComparatorArea comparator = new ComparatorArea();
Collections.sort(list, comparator);
/**
* 对区块自定义排序,顺序从高到低如下:
* 塔北
* 库车
* 塔中
* 塔西
* 塔河
* 盛业
* 新疆
*
*/
private class ComparatorArea implements Comparator{
Map<String,Integer> sortValue = new HashMap<String,Integer>();
public ComparatorArea(){
initSort();
}
public int compare(Object p1, Object p2) {
Object o1 = ((Map)p1).get("ITEM_AREA_NAME");
Object o2 = ((Map)p2).get("ITEM_AREA_NAME");
String key1 = o1 != null ? o1.toString() : "";
String key2 = o2 != null ? o2.toString() : "";
if(StringUtils.isEmpty(key1) && StringUtils.isEmpty(key2)){
return 0;//都为null或空串,相等
}else if(key1.equals(key2)){
return 0;
}else if(StringUtils.isEmpty(key1) && !StringUtils.isEmpty(key2)){
return 1;//null或空串越向后靠
}else if(!StringUtils.isEmpty(key1) && StringUtils.isEmpty(key2)){
return -1;//null或空串越向后靠
}else if(sortValue.get(key1) > sortValue.get(key2)){
return 1;
}else{
return -1;
}
}
//排序顺序,value越大,排序越靠前
private void initSort(){
sortValue.put("新疆", 7);
sortValue.put("盛业", 6);
sortValue.put("塔河", 5);
sortValue.put("塔西", 4);
sortValue.put("塔中", 3);
sortValue.put("库车", 2);
sortValue.put("塔北", 1);
}
}
如果排序对象是个实体类,实体类则直接实现Comparator接口,实现compare方法即可;实现Comparator接口时,可以使用泛型,如implements Comparator<User>;compare(User p1, User p2)
.
分享到:
相关推荐
8 对List排序 <br>4. 9 HashSet. LinkedHashSet和TreeSet <br>4. 10 列表. 集合与数组的互相转换 <br>4. 11 HashMap. Hashtable. LinkedHashMap和TreeMap <br>4. 12 对Map排序 <br>4. 13 Properties属性文件 <br>第...
69.zip<br>Smart Pointers and other Pointer classes<br>指针类(5KB)<END><br>70,70.zip<br>Sortable CObArray class<br>对CObArray类排序(5KB)<END><br>71,71.zip<br>Sortable CObList class<br>对CObList类排序(6...
对结果排序<br>12.4. 关联(Associations)<br>12.5. 动态关联对象获取(Dynamic association fetching)<br>12.6. 根据示例查询(Example queries)<br>13. 原生SQL查询<br>13.1. 创建一个基于SQL的Query<br>13.2....
对结果排序<br>12.4. 关联(Associations)<br>12.5. 动态关联对象获取(Dynamic association fetching)<br>12.6. 根据示例查询(Example queries)<br>13. 原生SQL查询<br>13.1. 创建一个基于SQL的Query<br>13.2....
Lucene根据关键词出现次数排序以及自定义排序,可以自定义优先级,包含list<map>字段排序与pom等
除了无法访问它的大小和不能使用索引来获得它的子变量:集合可以看作只能由<#list...>指令使用的受限sequences。 5、 方法:通过传递的参数进行计算,以新对象返回结果 方法变量通常是基于给出的参数计算值在数据...
protected List<Content> getList(Map<String, TemplateModel> params, Environment env) throws TemplateException { Integer[] ids = DirectiveUtils.getIntArray(PARAM_IDS, params); if (ids != null) { //...
2. <s:checkboxlist list=""></s:checkboxlist>-----多选框 3. <s:combobox list=""></s:combobox>-----下拉框 4. <s:component></s:component>-----图像符号 D: 1. <s:date/>-----获取日期格式 2. <s:...
输入:Text,list<Text> 输出:Text,Text OutputForamt 特殊组件 partitioner 数据分区 key.hashcode % reduceTaskNum combiner 本地reduce,在map阶段运行 看情况使用 排序&TopN; 共同好友计算 分布式...
4.4.3 numeric_limits<> 13 4.5 辅助函数 14 4.5.1 max、min 14 4.5.2 swap 15 4.6 头文件<cstddef>、<cstdlib> 15 4.6.1 <cstddef> 15 4.6.2 <cstdlib> 15 5 STL标准程序库 16 5.1 STL组件 16 5.1.1 分类 16 5.1.2 ...
<LI>登录时间:{maccms:userlogintime} </LI> <LI><A href="{maccms:path}index.php?m=user-index.html" target="_blank">进入用户中心</A></LI> <LI><A href="{maccms:path}index.php?m=user-logout.html">退出...
JHelper 是一个开源的共用JS库,它分层装了类似Java中的List, Map,StringBuffer以及自定义排序等集合,和方便灵活的Validate验证操作
注:本人刚入行,想把工作遇到的问题写下来。前段时间跟公司前端对接的时候,一个简单的数据库查询,但是前端说将结果按某个属性分组,每组单独一个集合,集合第一个元素为该属性,第二个元素为该属性值相同的所有...
,重点讲解Collection:集合框架体系List/Set/Map多种 实现和API ·玩转集合框架迭代器和HashCode和Equals重新排序 实战 ·实战teratori迭代器和自定义Comparable:排序接口 ·玩转ava操作文件File类常用操作 ·案例...
后端开发攻略(笔记) Golang 攻略 ...实现自定义排序规则 Python 攻略 基本数据类型 生成器 文件操作 并发 三方库 jieba wordcloud Python 连接数据库 Web 开发 爬虫 Web 框架 Django 爬虫框架 Scrapy
将多个集合使用一个<iterator/>标签完成迭代。 generatot标签:将指定的字符串按照规定的分隔符分解成多个子字符串。 merge标签:将多个集合拼接在一起。 subset标签:获取某个集合的子集合。 sort标签:多指定...
网站的插入模块,在侧边栏中显示带有商店列表的google map。 特征 在地图上绘制所有商店 在侧栏中显示商店列表,以提供地图导航 确定用户位置并对商店进行排序,显示最接近的第一位 显示到给定位置(步行或开车)到...
Java集合框架:常用的List、Set、Map等集合类及其实现方式、使用场景、遍历方法等。 异常处理:Java中的异常类型、异常处理机制、如何自定义异常等。 IO流:Java中常用的文件读写、序列化和反序列化等操作。 多线程...
数组排序 多维数组 命令行参数 面向对象编程 面向对象基础 方法 构造方法 方法重载 继承 多态 抽象类 接口 静态字段和静态方法 包 作用域 classpath和jar 模块 Java核心类 字符串和编码 ...
集合框架 Collection、List、Set、Map的接口及其实现类、迭代、Hash 算法与 hashCode 方法、comparable、泛型 chp12.异常 概念、分类、产生、传递、处理、自定义异常 chp13.线程 概念、创建、状态转换、数据共享、...