Java对List对象进行排序
为什么80%的码农都做不了架构师?>>>
有时候需要对List对象进行排序,如果每一处都去写一个排序方法,就会产生重复代码的坏味道,而且每一处都写,工作量会很大。
我们知道,Java提供了一个Collections.sort()方法可以对List排序,利用Java反射机制,很容易就能写出一个通用的排序方法。
为了防止出现不按照getter,setter规范命名的POJO类,我不打算动态调用getXXX()方法,而是直接获取对象的属性值。为了达到不论是否是public成员变量,都能获取到的目的,在获取到Field后,调用了setAccessible(true); 来设置访问权限。
具体代码如下:
[java] view plain copy
- /**
- * 对List对象按照某个成员变量进行排序
- * @param list List对象
- * @param sortField 排序的属性名称
- * @param sortMode 排序方式:ASC,DESC 任选其一
- */
- public static <T> void sortList(List<T> list, final String sortField, final String sortMode) {
- Collections.sort(list, new Comparator<T>() {
- @Override
- public int compare(T o1, T o2) {
- try {
- Class clazz = o1.getClass();
- Field field = clazz.getDeclaredField(sortField); //获取成员变量
- field.setAccessible(true); //设置成可访问状态
- String typeName = field.getType().getName().toLowerCase(); //转换成小写
- Object v1 = field.get(o1); //获取field的值
- Object v2 = field.get(o2); //获取field的值
- boolean ASC_order = (sortMode == null || "ASC".equalsIgnoreCase(sortMode));
- //判断字段数据类型,并比较大小
- if(typeName.endsWith("string")) {
- String value1 = v1.toString();
- String value2 = v2.toString();
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("short")) {
- Short value1 = Short.parseShort(v1.toString());
- Short value2 = Short.parseShort(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("byte")) {
- Byte value1 = Byte.parseByte(v1.toString());
- Byte value2 = Byte.parseByte(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("char")) {
- Integer value1 = (int)(v1.toString().charAt(0));
- Integer value2 = (int)(v2.toString().charAt(0));
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("int") || typeName.endsWith("integer")) {
- Integer value1 = Integer.parseInt(v1.toString());
- Integer value2 = Integer.parseInt(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("long")) {
- Long value1 = Long.parseLong(v1.toString());
- Long value2 = Long.parseLong(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("float")) {
- Float value1 = Float.parseFloat(v1.toString());
- Float value2 = Float.parseFloat(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("double")) {
- Double value1 = Double.parseDouble(v1.toString());
- Double value2 = Double.parseDouble(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("boolean")) {
- Boolean value1 = Boolean.parseBoolean(v1.toString());
- Boolean value2 = Boolean.parseBoolean(v2.toString());
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("date")) {
- Date value1 = (Date)(v1);
- Date value2 = (Date)(v2);
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else if(typeName.endsWith("timestamp")) {
- Timestamp value1 = (Timestamp)(v1);
- Timestamp value2 = (Timestamp)(v2);
- return ASC_order ? value1.compareTo(value2) : value2.compareTo(value1);
- }
- else {
- //调用对象的compareTo()方法比较大小
- Method method = field.getType().getDeclaredMethod("compareTo", new Class[]{field.getType()});
- method.setAccessible(true); //设置可访问权限
- int result = (Integer)method.invoke(v1, new Object[]{v2});
- return ASC_order ? result : result*(-1);
- }
- }
- catch (Exception e) {
- String err = e.getLocalizedMessage();
- System.out.println(err);
- e.printStackTrace();
- }
- return 0; //未知类型,无法比较大小
- }
- });
- }
后续有很多开发填坑的文章发布,如果对你有帮助,请支持和加关注一下
http://e22a.com/h.05ApkG?cv=AAKHZXVo&sm=339944
https://shop119727980.taobao.com/?spm=0.0.0.0
转载于:https://my.oschina.net/baishi/blog/367699
Java对List对象进行排序相关推荐
- java 集合中对象的排序 和去重
对list 集合对象中 重复度数据进行排序 1.实体类 中 实现 Comparable 接口中的compareTo 方法 用 什么来比较 集合中的排序 2.对集合中的的对象进行去重,重写 hashCo ...
- java如何实现成绩排序,小实例-实现对成绩总分由高到低的排序-Java中数组对象的排序...
//如何实现这对象数组排序 import java.util.Arrays; public class SortTotalScore { public static void main(String ...
- Java对数组对象进行排序
例如: 根据List中对象age属性, 将List进行倒叙排序. 排序前打印: [{"name":"王明0","age":0}, {&quo ...
- 如何在Java中对Collection对象进行排序?
排序集合的对象 (Sorting objects of the Collection) This concept is related to sorting and here we will see ...
- java map对象排序输出_java实现对象的排序(List和Map)
java实现对象的排序(List和Map) List和Map的排序 在实际的开发当中,我们经常 在文件浏览的时候经常有多种浏览方式,按时间整箱排序,逆向排序,按大小正逆向排序 ,按 按价格正逆向排序, ...
- Java通用工具类之按对象属性排序工具类
本工具类为按对象属性排序工具类,实现的功能: 1.按对象的一个属性和多个属性进行排序. 2.按对象属性正序和倒序排列. 3.完美支持int等基础类和Integer等包装类. 4.完美支持属性为实现了C ...
- 高薪程序员面试题精讲系列15之Java中的对象如何实现排序?
一. 面试题及剖析 1. 今日面试题 我们在项目开发时,有时候会遇到列表搜索查询等效果,其中大部分都可以利用SQL语句来实现,但也有些特殊的搜索排序利用SQL是很难实现的,比如对中文进行排序.说到排序 ...
- Java中根据对象的一个或多个属性进行排序
Java中根据对象的一个或多个属性进行排序 使用情景 解决方法:使用一个工具类:ListUtils 具体使用: 创建一个正常实体类,不用实现comparable接口 调用ListUtiles,并用测试 ...
- Java实现对象列表排序
Java实现多个对象排序(两种方式) 如果是Java自定义的对象,需要对多个对象进行排序,这里使用Java自身提供的排序函数Collections.sort();但是我们的对象需要支持这个函数,需要做 ...
最新文章
- 为什么说红外热成像测温设备是2020年最火的弱电设备?
- WinForm - 两个窗体之间的方法调用
- c语言实现图片卷积_卷积神经网络(CNN)Python的底层实现——以LeNet为例
- 关于spring mvc时间类型绑定失败解决方法
- 微信防撤回python代码_python实现微信防撤回神器
- Codeforces Round 253 (Div. 2)
- 【心电信号】基于matlab瞬时抑制心电信号IIR滤波【含Matlab源码 1533期】
- 质量工程师(QA)岗位初介绍
- gf(2 4)有限域的乘法c语言实现,有限域GF(2^n)的C语言实现浅析
- Labelimg讲解
- 用MACD决策树模型预测股票趋势
- ST-Link v2 下载 出现target dll has been cancelled 的错误的解决方法
- C#数字转字母,ASCII码转换
- Knowledge Graph Embedding: A Survey of Approaches and Applications【翻译】
- 《需求工程--软件建模与分析》笔记
- 黑盒测试——NextDate函数测试(判定表驱动法)
- 数据结构:满二叉树,完全二叉树,非完全二叉树 的区别
- 关于五笔输入法与EXCEL不兼容解决方法
- 货来,速抢 — 天选 2 首发评测
- Java 208道面试题及部分答案(后期继续做)