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排序问题的主要内容,如果未能解决你的问题,请参考以下文章

java List对象排序的问题……

java中list排序

java中两个list集合如何排序

java list排序出错

java怎么对list进行排序

java list<T> 根据两个字段排序