有时候,我们会有这样的需求:通过制定的类中的元素,对多个实例对象进行排列显示。
那么,今天我为大家写了这样一个类,以便使用
话不多说,贴上源码
public class ListSort<E>{ /** * * @param list 要排序的集合 * @param method 要排序的实体的属性所对应的get方法 * @param sort desc 为正序 */ public void Sort(List<E> list, final String method, final String sort) { // 用内部类实现排序 Collections.sort(list, new Comparator<E>() { public int compare(E a, E b) { int ret = 0; try { // 获取m1的方法名 Method m1 = a.getClass().getMethod(method, new Class[0]); // 获取m2的方法名 Method m2 = b.getClass().getMethod(method, new Class[0]); if (sort != null && "desc".equals(sort)) { ret = m2.invoke(((E) b), new Object[]{}).toString().compareTo(m1.invoke(((E) a), new Object[]{}).toString()); } else { // 正序排序 ret = m1.invoke(((E) a), new Object[]{}).toString().compareTo(m2.invoke(((E) b), new Object[]{}).toString()); } } catch (NoSuchMethodException ne) { System.out.println(ne); } catch (IllegalArgumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (InvocationTargetException e) { // TODO Auto-generated catch block e.printStackTrace(); } return ret; } }); } }
好了 ,我是用的反射的原理来进行比较的 ,如果有更好的方法,欢迎探讨学习。