package com.cyyun.test; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; public class SortTest { static Map<String, Integer> sortNameMap = new HashMap<String, Integer>(); static { sortNameMap.put("张三", 1); sortNameMap.put("王五", 2); sortNameMap.put("赵六", 3); sortNameMap.put("李四", 4); } public static Integer getSortNameMapByKey(String key) { for (String s : sortNameMap.keySet()) { if (key.contains(s)) { return sortNameMap.get(s); } } return sortNameMap.size()+1; } public static <T> void sort(List<T> list, final List<Comparator<T>> comparatorList) { if (comparatorList.isEmpty()) {// Always equals, if no Comparator. throw new IllegalArgumentException("comparatorList is empty."); } Comparator<T> comparator = new Comparator<T>() { public int compare(T o1, T o2) { for (Comparator<T> c : comparatorList) { if (c.compare(o1, o2) > 0) { return 1; } else if (c.compare(o1, o2) < 0) { return -1; } } return 0; } }; Collections.sort(list, comparator); } public static <E> void sortByMethod(List<E> list, final String method, final boolean reverseFlag) { Collections.sort(list, new Comparator<Object>() { @SuppressWarnings("unchecked") public int compare(Object arg1, Object arg2) { int result = 0; try { Method m1 = ((E) arg1).getClass().getMethod(method, null); Method m2 = ((E) arg2).getClass().getMethod(method, null); Object obj1 = m1.invoke(((E) arg1), null); Object obj2 = m2.invoke(((E) arg2), null); if (obj1 instanceof String) { if (method.toLowerCase().contains("name")) { Integer sort1 = getSortNameMapByKey((String) (obj1)); Integer sort2 = getSortNameMapByKey((String) (obj2)); result = sort1.compareTo(sort2); } else { // 字符串 result = obj1.toString().compareTo(obj2.toString()); } } else if (obj1 instanceof Date) { // 日期 long l = ((Date) obj1).getTime() - ((Date) obj2).getTime(); if (l > 0) { result = 1; } else if (l < 0) { result = -1; } else { result = 0; } } else if (obj1 instanceof Integer) { // 整型(Method的返回参数可以是int的,因为JDK1.5之后,Integer与int可以自动转换了) result = (Integer) obj1 - (Integer) obj2; } else { // 目前尚不支持的对象,直接转换为String,然后比较,后果未知 result = obj1.toString().compareTo(obj2.toString()); System.err .println("MySortList.sortByMethod方法接受到不可识别的对象类型,转换为字符串后比较返回..."); } if (reverseFlag) { // 倒序 result = -result; } } catch (NoSuchMethodException nsme) { nsme.printStackTrace(); } catch (IllegalAccessException iae) { iae.printStackTrace(); } catch (InvocationTargetException ite) { ite.printStackTrace(); } return result; } }); } public static void main(String[] args) { System.out.println("2".compareTo("1")); List<Person> list = new ArrayList<Person>(); Person p = new Person(); p.setId(1); p.setName("张三111"); list.add(p); p = new Person(); p.setId(2); p.setName("李四111"); list.add(p); p = new Person(); p.setId(3); p.setName("王五111"); list.add(p); p = new Person(); p.setId(4); p.setName("赵六1111"); list.add(p); p = new Person(); p.setId(5); p.setName("小王1111"); list.add(p); p = new Person(); p.setId(6); p.setName("老王1111"); list.add(p); sortByMethod(list, "getName", true); System.out.println("中文名称正序排列:"); for (Person pp : list) { System.out.println(pp.getId() + "," + pp.getName()); } } } class Person { private int id; private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getId() { return id; } public void setId(int id) { this.id = id; } }
相关推荐
在Java编程语言中,对包含中文、数字和字母的数据进行排序是一项常见的任务。这个场景下,我们关注的是如何实现一个自定义的排序规则,按照数字、字母和汉字的顺序进行排列。以下是对这一主题的详细解释。 首先,...
可以自定义比较器来指定排序规则。 **示例代码分析**: ```java public class Main { public static void main(String[] args) throws Exception { Scanner cin = new Scanner(System.in); String str = cin....
这些方法都接受一个待排序的数组和一个字符串参数`sortType`,用于指定排序的方向(升序或降序)。例如: ```java public void bubbleSort(int[] data, String sortType) { if (sortType.equals("asc")) { // ...
下面我们将深入探讨如何在Java中实现集合的分组与排序。 1. **集合分组**: 集合分组通常涉及到`GroupingBy`操作,这在Java 8引入的流(Stream)API中得到了很好的支持。`Collectors.groupingBy`方法允许我们将...
在Java中,声明数组时需要指定元素类型,例如`int[] arr`声明了一个整型数组。 选择排序的基本步骤如下: 1. **找到最小元素**:遍历整个数组,找到当前未排序部分的最小元素。 2. **交换位置**:将这个最小元素与...
因此,我们需要创建自定义的Comparator来指定排序规则。 一个对象可能有多个属性,比如`Person`类可能包含`name`、`age`和`salary`等属性。如果我们想根据这些属性进行排序,我们可以创建一个Comparator的实现类,...
### Java集合排序及Java集合类详解 #### 一、集合框架概述 集合框架是Java编程语言的核心组件之一,用于组织和操作数据集。Java集合框架提供了多种数据结构,包括列表(List)、集(Set)和映射(Map),这些数据结构...
通过以上介绍,我们可以看出Java Stream API提供了灵活且高效的方式来处理日期排序。无论是在简单的日期列表还是复杂的数据结构中,都可以轻松地实现排序功能。实践过程中,可以根据实际需求选择合适的日期类型和...
本篇将详细介绍如何根据指定字段对`List`中的对象进行排序,以`Student`类为例,假设每个`Student`都有一个`grad`属性表示成绩。 首先,我们需要创建`Student`类,定义`grad`属性和getter/setter方法: ```java ...
我们可以使用泛型来指定排序的字段,然后使用反射机制来动态地取得方法。 例如,我们可以使用以下代码来对 UserInfo 对象的 userId 字段进行排序: Java 代码 SortList<UserInfo> sortList = new SortList(); sort...
标题中的“Java处理排序后的数组比没有排序的快”指的是在执行特定操作时,如搜索、遍历或计算,对已经排序的数组进行处理通常比处理无序数组更高效。这是因为排序后的数组具有一定的顺序性,可以利用这种顺序性来...
在这个例子中,我们首先创建了一个`Collator`实例,指定了`Locale.CHINA`,这样排序规则就会按照中文的习惯进行。然后,通过`setStrength()`方法设置排序强度,这里我们选择了`PRIMARY`,这意味着它将忽略字符的大小...
在Java编程中,对象数组排序是一项常见的任务,特别是在处理复杂数据结构时。当我们需要根据对象的多个属性进行排序时,情况会变得稍微复杂。本文将深入探讨如何在Java中实现这个功能,结合给出的标签“源码”和...
java 中的排序 Java 中的排序可以分为三种类型:简单类型排序、内部对象实现 Comparable 和外部对象实现 Comparator。 简单类型排序 简单类型包括 byte, char, short, int, long, float, double 等数据类型。这些...
如果元素类型没有实现`Comparable`,你可以传入一个`Comparator`实例来指定排序规则。 - **使用Arrays.sort()**: - 对于数组,你可以使用`Arrays.sort()`方法。同样,如果数组元素实现了`Comparable`,则按自然...
根据给定的信息,我们可以深入探讨冒泡排序算法及其在Java中的实现细节。冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复...
如果需要有序的Map,可以使用TreeMap,它会根据键的自然顺序进行排序,或者使用实现SortedMap接口的其他Map实现类,并指定排序规则。 在这个例子中,我们看到通过使用TreeMap来实现Map元素的排序。TreeMap是基于...
### Java集合排序及java集合类详解 #### 集合框架概述 集合是Java编程语言中非常核心且广泛使用的部分,对于深入理解和高效使用Java语言至关重要。本文将围绕Java集合框架进行详细介绍,包括Collection、List、Set...
当我们向TreeSet添加元素时,它们会自动按照指定的顺序排序。如果元素是Comparable的,那么它们会根据自然顺序排序;否则,我们需要提供一个Comparator。 ```java TreeSet<MyObject> treeSet = new TreeSet...
本项目"GUI的Java课表排序"聚焦于利用拓扑排序算法解决实际问题,为用户提供了一个直观易用的课表优化工具。 拓扑排序是一种对有向无环图(DAG,Directed Acyclic Graph)进行线性排序的方法。在这个课表排序应用中...