java List 排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java List 排序相关的知识,希望对你有一定的参考价值。

把List容器中的数字元素“6”,“5”,“”,“3”,“1”,“2”,“4”按照从大到小的顺序重新排放
最好写出代码来,谢谢!

参考技术A List容器貌似是不支持直接写数字的,你是不是通过String的方式放进去的呢?

public static void main(String[] args)
test();


public static void test()
List<String> list = new ArrayList<String>();
list.add("6");
list.add("5");
list.add("");
list.add("3");
list.add("1");
list.add("2");
list.add("4");

Collections.sort(list);

System.out.println(list);


另外,如果是数字,也是一样的处理方式,关于数组排序了解下Collections的API就好,见参考资料

参考资料:http://gceclub.sun.com.cn/Java_Docs/html/zh_CN/api/index.html

本回答被提问者采纳
参考技术B List list = new Vector();
list.add("6");
list.add("5");
list.add("");
list.add("3");
list.add("1");
list.add("2");
list.add("4");
Collections.sort(list);
for(int i = 0; i < list.size(); i++)
System.out.println(list.get(i));

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

java怎么对list进行排序

JAVA中list排序问题

java中两个list集合如何排序

Java的List怎么排序啊?

Java的List怎么排序啊?

关于java list的排序问题