Java 多字段排序Comparator(兼容Date,Integer,Doubel,Long)
Java 反射类:ReflexUtil
public class ReflexUtil {
static Logger logger = LoggerFactory.getLogger(ReflexUtil.class);
//getMethod
static public Object invokeMethod(String propertiesName, Object object) {
try {
if(object==null) return null;
if (!propertiesName.contains(".")) {
String methodName = "get"+getMethodName(propertiesName);
Method method = object.getClass().getMethod(methodName);
return method.invoke(object);
}
String methodName = "get"+getMethodName(propertiesName.substring(0,propertiesName.indexOf(".")));
Method method = object.getClass().getMethod(methodName);
return invokeMethod(propertiesName.substring(propertiesName.indexOf(".")+1), method.invoke(object));
} catch (Exception e) {
logger.error(e.toString(), e);
return null;
}
}
private static String getMethodName(String fildeName) {
byte[] items = fildeName.getBytes();
items[0] = (byte) ((char) items[0] - 'a' + 'A');
return new String(items);
}
public static void main(String args[]) {
Video video = new Video();
Album album = new Album();
album.setAlbumId(346l);
video.setAlbum(album);
video.setVideoId(126l);
System.out.println(ReflexUtil.invokeMethod("album.albumId", video));
}
}
Java 对象排序 : CompareUtil ()
package com.gochinatv.vrs.framework.util; import com.alibaba.fastjson.JSONObject;
import com.gochinatv.vrs.framework.bean.LabelAlbum;
import com.gochinatv.vrs.framework.bean.Video; import java.util.*; /**
* Created by shhao
* Date: 14-5-6.
* Time:下午4:48
*/
public class CompareUtil { //sort 1正序 -1 倒序 filed 多字段排序
public static <T> Comparator createComparator(int sort, String... filed) {
return new ImComparator(sort, filed);
} public static class ImComparator implements Comparator {
int sort = 1;
String[] filed; public ImComparator(int sort, String... filed) {
this.sort = sort == -1 ? -1 : 1;
this.filed = filed;
} @Override
public int compare(Object o1, Object o2) {
int result = 0;
for (String file : filed) {
Object value1 = ReflexUtil.invokeMethod(file, o1);
Object value2 = ReflexUtil.invokeMethod(file, o2);
if (value1 == null || value2 == null) {
continue;
}
if (value1 instanceof Integer) { //Integer整数序排序
int v1 = Integer.valueOf(value1.toString());
int v2 = Integer.valueOf(value2.toString());
if (v1 == v2) continue;
if (sort == 1) {
return v1 - v2;
} else if (sort == -1) {
return v2 - v1;
}
} else if (value1 instanceof Date) { //Date类型排序
Date d1 = (Date) value1;
Date d2 = (Date) value2;
if (d1.compareTo(d2) == 0) continue;
if (sort == 1) {
return d1.compareTo(d2);
} else if (sort == -1) {
return d2.compareTo(d1);
}
} else if (value1 instanceof Long) { //Long排序
long v1 = Long.valueOf(value1.toString());
long v2 = Long.valueOf(value2.toString());
if (v1 == v2) continue;
if (sort == 1) {
return v1 > v2 ? 1 : -1;
} else if (sort == -1) {
return v2 > v1 ? 1 : -1;
}
} else if (value1 instanceof Double) { //Double排序
Double v1 = Double.valueOf(value1.toString());
Double v2 = Double.valueOf(value2.toString());
if (v1 == v2) continue;
if (sort == 1) {
return v1 > v2 ? 1 : -1;
} else if (sort == -1) {
return v2 > v1 ? 1 : -1;
}
} } return result;
}
} public static void main(String args[]) {
Video label1 = new Video();
label1.setDisplayOrder(1);
label1.setCreateTime(DateUtils.convert("2014-01-01"));
Video label2 = new Video();
label2.setDisplayOrder(3);
label2.setCreateTime(DateUtils.convert("2014-01-02"));
Video label3 = new Video();
label3.setDisplayOrder(2);
label3.setCreateTime(DateUtils.convert("2014-01-03"));
Video label4 = new Video();
label4.setDisplayOrder(2);
label4.setCreateTime(DateUtils.convert("2014-01-01"));
Video label5 = new Video();
label5.setDisplayOrder(4);
label5.setCreateTime(DateUtils.convert("2014-01-05"));
List<Video> list = new ArrayList<Video>();
list.add(label1);
list.add(label2);
list.add(label3);
list.add(label4);
list.add(label5);
Collections.sort(list, CompareUtil.createComparator(1, "createTime", "displayOrder"));
for (int i = 0; i < list.size(); i++) {
Video labelAlbum = list.get(i);
System.out.println("displayorder:" + labelAlbum.getDisplayOrder() + " sequence:" + DateUtils.convert(labelAlbum.getCreateTime()));
}
}
}
Java 多字段排序Comparator(兼容Date,Integer,Doubel,Long)的更多相关文章
- Java 8 Lambda排序 : Comparator example
1. Classic Comparator example. Comparator<Developer> byName = new Comparator<Developer>( ...
- Comparable与Comparator,java中的排序与比较
1:比较和排序的概念 比较:两个实体类之间按>,=,<进行比较. 排序:在集合类中,对集合类中的实体进行排序.排序基于的算法基于实体类提供的比较函数. 基本型别都提供了默认的比较算法,如s ...
- Vector 多字段排序的Java实现
要求实现: Vector 多字段排序,其中首元素不参与排序,第一二三字段升序,空排到前面. //这里是Vector的元素定义 public class AVectorElement { private ...
- java的list集合如何根据对象中的某个字段排序?
转自:http://blog.csdn.net/wangjuan_01/article/details/51351633 List集合按某个字段排序 package wjtest_01; import ...
- java实现按对象某个字段排序,排序字段和规则自定义
@SuppressWarnings({ "unchecked", "rawtypes" }) private <T> void sort(List& ...
- JAVA实现按列表中元素的时间字段排序
JAVA代码实现按列表中元素的时间字段排序 导语: 工作中遇到一个问题,调用第三方接口返回的数据没有按时间倒序排列,测试说要加,然后在网上找到一个解决办法,这里记录一下 需求: 如下图列表,按生日进行 ...
- Java TreeSet集合 比较器排序Comparator的使用
比较器排序Comparator的使用 存储学生对象,并遍历,创建TreeSet集合使用带参构造方法 要求,按照学生年龄从小到大排序,如果年龄相同,则按照姓名的字母循序排序 结论 用TreeSet集合存 ...
- 在Java中使用Collections.sort 依据多个字段排序
一.如何使用Collections工具类进行排序 使用Collections工具类进行排序主要有两种方式: 1.对象实现Comparable接口,重写compareTo方法 /** * @author ...
- ElasticSearch java API 按照某个字段排序
searchRequestBuilder.addSort("publish_time", SortOrder.DESC); 按照某个字段排序的话,hit.getScore()将会失 ...
随机推荐
- Win7上IIS发布网站系统\部署项目
1.系统已经安装IIS,如果没有安装,请到[控制面板]→[程序]→[程序和功能]→[打开或关闭Windows功能],选中Internet 信息服务Web管理工具下面的所有选项,确定:如下图 2.发布文 ...
- Linq中字段数据类型转换问题(Linq to entity,LINQ to Entities 不识别方法"System.String ToString()"问题解决)
1.在工作中碰到这样一个问题: 使用linq时,需要查询两个表,在这两张表中关联字段分别是int,和varchar()也就是string,在linq中对这两个字段进行关联, 如果强制类型转换两个不同类 ...
- QT 5.1.1 for Android 开发环境搭建与配置【Windows 7】
前言:本人操作系统为Windows7 64位,用的是32位的安装包,32位系统没有验证. 一.首先下载以下安装包,如果提供的链接失效请自行下载: (1) Android SDK (Windows 32 ...
- keepalived + nginx
本文主要介绍keepalived的安装,Nginx自行解决,也可以使用httpd.随便任何服务都可以... keepalived 官网http://www.keepalived.org/index.h ...
- storm-kafka教程
一.原理介绍 本文内容参考:https://github.com/apache/storm/tree/master/external/storm-kafka#brokerhosts (一)使用st ...
- 手机时间选择插件 Jquery
// 时间选择 var currYear = (new Date()).getFullYear() var opt_data = { preset: 'date', //日期 theme: 'andr ...
- LRU缓存算法 - C++版
LRU是Least Recently Used的缩写,意思是最近最少使用,它是一种Cache替换算法. 实现思路: hashtable + 双向链表 时间复杂度: 插入,查找,删除:O(1) 空间使用 ...
- Jsonp 解决跨域问题
话不多说直接贴代码: $.ajax({ async: false, url: 'http://****.****.com/Handler.ashx?vueId=iwNavpicS2', type: & ...
- CentOS 6.5 + Nginx 1.8.0 + PHP 5.6(with PHP-FPM) 负载均衡源码安装 之 (一)Nginx安装篇
CentOS 6.5 minimal安装不再赘述 Nginx源码安装 1.安装wget下载程序 yum -y install wget 2.安装编译环境:gcc gcc-c++ automake au ...
- 检测IIS应用程序池对象 回收
function RecycleYourAppPool([string] $poolName){ Import-Module WebAdministration #获取所有Application Po ...