`
m635674608
  • 浏览: 5029155 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

java 指定排序

    博客分类:
  • java
 
阅读更多
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编程语言中,对包含中文、数字和字母的数据进行排序是一项常见的任务。这个场景下,我们关注的是如何实现一个自定义的排序规则,按照数字、字母和汉字的顺序进行排列。以下是对这一主题的详细解释。 首先,...

    java冒泡排序java冒泡排序集锦方法!

    可以自定义比较器来指定排序规则。 **示例代码分析**: ```java public class Main { public static void main(String[] args) throws Exception { Scanner cin = new Scanner(System.in); String str = cin....

    java排序.txt

    这些方法都接受一个待排序的数组和一个字符串参数`sortType`,用于指定排序的方向(升序或降序)。例如: ```java public void bubbleSort(int[] data, String sortType) { if (sortType.equals("asc")) { // ...

    java 集合分组与排序

    下面我们将深入探讨如何在Java中实现集合的分组与排序。 1. **集合分组**: 集合分组通常涉及到`GroupingBy`操作,这在Java 8引入的流(Stream)API中得到了很好的支持。`Collectors.groupingBy`方法允许我们将...

    java 选择排序法

    在Java中,声明数组时需要指定元素类型,例如`int[] arr`声明了一个整型数组。 选择排序的基本步骤如下: 1. **找到最小元素**:遍历整个数组,找到当前未排序部分的最小元素。 2. **交换位置**:将这个最小元素与...

    java List中对象多属性排序及各属性排序设置

    因此,我们需要创建自定义的Comparator来指定排序规则。 一个对象可能有多个属性,比如`Person`类可能包含`name`、`age`和`salary`等属性。如果我们想根据这些属性进行排序,我们可以创建一个Comparator的实现类,...

    Java集合排序及java集合类详解.pdf

    ### Java集合排序及Java集合类详解 #### 一、集合框架概述 集合框架是Java编程语言的核心组件之一,用于组织和操作数据集。Java集合框架提供了多种数据结构,包括列表(List)、集(Set)和映射(Map),这些数据结构...

    java使用stream对日期排序

    通过以上介绍,我们可以看出Java Stream API提供了灵活且高效的方式来处理日期排序。无论是在简单的日期列表还是复杂的数据结构中,都可以轻松地实现排序功能。实践过程中,可以根据实际需求选择合适的日期类型和...

    java List排序demo

    本篇将详细介绍如何根据指定字段对`List`中的对象进行排序,以`Student`类为例,假设每个`Student`都有一个`grad`属性表示成绩。 首先,我们需要创建`Student`类,定义`grad`属性和getter/setter方法: ```java ...

    java中list排序

    我们可以使用泛型来指定排序的字段,然后使用反射机制来动态地取得方法。 例如,我们可以使用以下代码来对 UserInfo 对象的 userId 字段进行排序: Java 代码 SortList&lt;UserInfo&gt; sortList = new SortList(); sort...

    Java处理排序后的数组比没有排序的快.docx

    标题中的“Java处理排序后的数组比没有排序的快”指的是在执行特定操作时,如搜索、遍历或计算,对已经排序的数组进行处理通常比处理无序数组更高效。这是因为排序后的数组具有一定的顺序性,可以利用这种顺序性来...

    关于中文英文混合排序javaDemo

    在这个例子中,我们首先创建了一个`Collator`实例,指定了`Locale.CHINA`,这样排序规则就会按照中文的习惯进行。然后,通过`setStrength()`方法设置排序强度,这里我们选择了`PRIMARY`,这意味着它将忽略字符的大小...

    JAVA 对象数组按照多个属性进行排序

    在Java编程中,对象数组排序是一项常见的任务,特别是在处理复杂数据结构时。当我们需要根据对象的多个属性进行排序时,情况会变得稍微复杂。本文将深入探讨如何在Java中实现这个功能,结合给出的标签“源码”和...

    java中的排序.ppt

    java 中的排序 Java 中的排序可以分为三种类型:简单类型排序、内部对象实现 Comparable 和外部对象实现 Comparator。 简单类型排序 简单类型包括 byte, char, short, int, long, float, double 等数据类型。这些...

    java 对象 排序

    如果元素类型没有实现`Comparable`,你可以传入一个`Comparator`实例来指定排序规则。 - **使用Arrays.sort()**: - 对于数组,你可以使用`Arrays.sort()`方法。同样,如果数组元素实现了`Comparable`,则按自然...

    值得看看冒泡排序法java

    根据给定的信息,我们可以深入探讨冒泡排序算法及其在Java中的实现细节。冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复...

    java实现的map排序

    如果需要有序的Map,可以使用TreeMap,它会根据键的自然顺序进行排序,或者使用实现SortedMap接口的其他Map实现类,并指定排序规则。 在这个例子中,我们看到通过使用TreeMap来实现Map元素的排序。TreeMap是基于...

    Java集合排序及java集合类详解(Collection、List、Map、Set)

    ### Java集合排序及java集合类详解 #### 集合框架概述 集合是Java编程语言中非常核心且广泛使用的部分,对于深入理解和高效使用Java语言至关重要。本文将围绕Java集合框架进行详细介绍,包括Collection、List、Set...

    Java 对象排序详解.rar_java 对象排序_对象_排序

    当我们向TreeSet添加元素时,它们会自动按照指定的顺序排序。如果元素是Comparable的,那么它们会根据自然顺序排序;否则,我们需要提供一个Comparator。 ```java TreeSet&lt;MyObject&gt; treeSet = new TreeSet...

    GUI的Java课表排序

    本项目"GUI的Java课表排序"聚焦于利用拓扑排序算法解决实际问题,为用户提供了一个直观易用的课表优化工具。 拓扑排序是一种对有向无环图(DAG,Directed Acyclic Graph)进行线性排序的方法。在这个课表排序应用中...

Global site tag (gtag.js) - Google Analytics