JAVA中list排序问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA中list排序问题相关的知识,希望对你有一定的参考价值。
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.lang.reflect.Method;
import java.lang.reflect.InvocationTargetException;
/**
* @author jardot
* @version 1.0
* 通用排序
*/
public class SortList<E>
public void Sort(List<E> list, final String method, final String sort)
Collections.sort(list, new Comparator()
public int compare(Object a, Object b)
int ret = 0;
try
Method m1 = ((E)a).getClass().getMethod(method, null);
Method m2 = ((E)b).getClass().getMethod(method, null);
if(sort != null && "desc".equals(sort))//倒序
ret = m2.invoke(((E)b), null).toString().compareTo(m1.invoke(((E)a), null).toString());
else//正序
ret = m1.invoke(((E)a), null).toString().compareTo(m2.invoke(((E)b), null).toString());
catch(NoSuchMethodException ne)
System.out.println(ne);
catch(IllegalAccessException ie)
System.out.println(ie);
catch(InvocationTargetException it)
System.out.println(it);
return ret;
);
ret = m1.invoke(((E)a), null).toString().compareTo(m2.invoke(((E)b), null).toString());这条代码怎么就能够为list重新排序呢?在下小鸟鸟,望各位大大指教!
我为了方便解释、写了一个测试类
/** test for reflex */
public class Model
private String name;
private String content;
public Model()
this.name = "my name";
this.content = "a long text";
public void setName(String name)
this.name = name;
public String getName()
return name;
public String getContent()
return content;
//测试
public void test() throws Exception
Model model = new Model();
Method m1 = model.getClass().getMethod("getName", null);
System.out.println(m1.invoke(model, null));
public static void main(String args[])
try
new Model().test("getName");
catch (Exception e)
e.printStackTrace();
首先调用test,传递一个method过去;
通过反射机制(这里用到了getMethod、invoke,我比较喜欢getField)、获取到m1对象的getName方法,getMethod第一个参数为方法名、第二个是给这个method的参数的类型,
If parameterTypes is null, it is treated as if it were an empty array,如果为null,表示没有参数;(即 getName()方法);
然后在通过 invoke 注入参数;第一个是相应对象的引用、第二个是参数值(刚刚的是类型,现在才是值);
If the underlying method is static, then the specified obj argument is ignored. It may be null,也就是说static的方法第一个参数是null;
我们要调用的是getName(),那么就是 m1.invoke(model,null)了;
执行结果为:my name ;相当于调用了getName()方法.
绕了一圈也就是 model.getName() == model.getClass().getMethod("getName",null).invoke(model,null);
对于有参数的,调整为
public void test(String method) throws Exception
Model model = new Model();
Method m1 = model.getClass().getMethod(method, String.class);
m1.invoke(model, "can you");
System.out.println(model.getName());
结果:can you
接下来上边的题目就简单了,
public void Sort(List<E> list, final String method, final String sort)
这里给出了method,接下来是一个内部类的处理;自定义一个comparator,
Method m1 = ((E) a).getClass().getMethod(method, null);
这里就是获取method方法,他没有参数。
m1.invoke(((E)a), null).toString()
这里是得到对象a调用方法method之后的返回值。
ret = m1.invoke(((E)a), null).toString().compareTo(m2.invoke(((E)b), null).toString());
而这里就是比较两个对象method方法的返回值
将ret交给sort进行排序;
就像3楼说的、真正排序的是sort方法,下面的只是对一个类中某个方法的返回值进行比较 参考技术A compareTo 只是比较2个字符串,不能进行排序
String s1 = "abc";
String s2 = "abcd";
String s3 = "abcdfg";
String s4 = "1bcdfg";
String s5 = "cdfg";
String s6="abc";
System.out.println( s1.compareTo(s2) ); // -1 (前面相等,s1长度小1)
System.out.println( s1.compareTo(s3) ); // -3 (前面相等,s1长度小3)
System.out.println( s1.compareTo(s4) ); // 48 ("a"的ASCII码是97,"1"的的ASCII码是49,所以返回48)
System.out.println( s1.compareTo(s5) ); //-2
System.out.println( s1.compareTo(s6) ); // 0
比较方法其实就是对字符串中的字符逐个比较ASCII 值相减,如果2个字符串是包含关系返回长度差。Collections.sort方法才是对LIST 进行排序的方法。本回答被提问者和网友采纳 参考技术B 这是根据Collections.sort重载方法来实现 list比较排序
compare 方法返回int类型参数实现正序和倒序排列
那我们来分析一下这句
ret = m1.invoke(((E)a), null).toString().compareTo(m2.invoke(((E)b), null).toString());
method m1 invoke方法中 将Object a强制转换为实体E类型 类型数组null 之后to成String 返回类型,与m2的invoke方法返回类型进行字符比较。 其结果返回的int类型 是compare 方法的返回类型。
Collections.sort将Sort方法中的参数list 进行排序,
ret = m2.invoke(((E)b), null).toString().compareTo(m1.invoke(((E)a), null).toString());
ret = m1.invoke(((E)a), null).toString().compareTo(m2.invoke(((E)b), null).toString());
这两句返回参数理论上是相反的
不用为此纠结 这只是个实例 有不明白的 可以Hi我 ms_compound 参考技术C m1.invoke通过反射,调用方法
compareTo.按字典顺序比较两个字符串 参考技术D 看来我还是要好好看书啊
java如何让list按照list里面的某个字段排序,list里面的有很多字段!
例如:list=[COUNTTICKET=1, PRECOUNTOUT=2, COUNTTICKET=6, PRECOUNTOUT=7, COUNTTICKET=7, PRECOUNTOUT=7, COUNTTICKET=1, PRECOUNTOUT=1]
求大侠帮忙下!
给你个例子看下
import java.util.ArrayList;import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class $
public static void main(String[] args)
List<Map<String, Integer>> data = new ArrayList<Map<String, Integer>>();
init(data);
System.out.println("排序前:");
System.out.println(data);
sort(data);
System.out.println("排序后:");
System.out.println(data);
private static void sort(List<Map<String, Integer>> data)
Collections.sort(data, new Comparator<Map>()
public int compare(Map o1, Map o2)
Integer a = (Integer) o1.get("PRECOUNTOUT");
Integer b = (Integer) o2.get("PRECOUNTOUT");
// 升序
return a.compareTo(b);
// 降序
// return b.compareTo(a);
);
private static void init(List<Map<String, Integer>> data)
Map<String, Integer> map = new HashMap<String, Integer>();
map.put("COUNTTICKET", 1);
map.put("PRECOUNTOUT", 2);
data.add(map);
map = new HashMap<String, Integer>();
map.put("COUNTTICKET", 6);
map.put("PRECOUNTOUT", 7);
data.add(map);
map = new HashMap<String, Integer>();
map.put("COUNTTICKET", 8);
map.put("PRECOUNTOUT", 5);
data.add(map);
map = new HashMap<String, Integer>();
map.put("COUNTTICKET", 2);
map.put("PRECOUNTOUT", 3);
data.add(map);
参考技术A 让你的list的泛型实现java.lang.Comparable接口即可 参考技术B 泛型类实现Comparable接口,重写 compareTo方法。 参考技术C 使用ArrayList,是有序的
以上是关于JAVA中list排序问题的主要内容,如果未能解决你的问题,请参考以下文章