java中List对象排序通用方法
本文实例讲述了java中list对象排序通用方法。分享给大家供大家参考。具体分析如下:
在数据库中查出来的列表list中,往往需要对不同的字段重新排序,一般的做法都是使用排序的字段,重新到数据库中查询。如果不到数据库查询,直接在第一次查出来的list中排序,无疑会提高系统的性能。
只要把第一次查出来的结果存放在session中,就可以对list重新排序了。一般对list排序可以使用collections.sort(list),但如果list中包含是一个对象的话,这种方法还是行不通的。那要怎么排序呢?如果有一个userinfo对象,包含如下字段:
private java.lang.integer userid; private java.lang.string username; private java.util.date birthdate; private java.lang.integer age;
那么现在要对userid排序,你可能会使用下面的方法:
collections.sort(list, new comparator() { public int compare(object a, object b) { int one = ((order)a).getuserid (); int two = ((order)b).getuserid (); return one- two ; } });
这样,如果要实现对userinfo列表各字段排序,是不是每个字段都写一段如上所示的代码呢?那当然不是我们所需要的结果。写程序要写得越来越精练,不能越写越冗余。能不能写一个通用的方法呢?答案是肯定的,但首先必须能解决下面三个问题:
1.可以使用泛型;
2.能够使用通用的比较方法,比如compareto;
3.有没有类似泛型、泛型方法那样的泛方法?
第1个问题可以解决,第2个问题难度也不是很大,因为java所有的类型都继承于object,都有一个tostring的方法,暂且可以把所有类型转换成string,然后用compareto作比较。第3个问题,日前还没有我们需要的泛方法。不过我们可否变通一下,使用getmethod和invoke方法动态的取出方法出来。完成代码如下:
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; } }); } }
看看上面的代码,我们是不是成功地解决了上面三个问题,并且还加进了正倒序。代码中没有用到具体的对象和类型,已经具有通用性了,我们用了一个泛型e,如果要对userinfo的userid排序的话,可以把方法名用字符串的形式用参数传进去:例如“getuserid”。可以使用下面提供的代码测试一下:
//test.java package test; import java.util.arraylist; import java.util.list; import java.text.simpledateformat; public class test { public static void main(string[] args)throws exception{ list<userinfo> list = new arraylist<userinfo>(); simpledateformat formater = new simpledateformat("yyyy-mm-dd"); list.add(new userinfo(3,"b",formater.parse("1980-12-01"),11)); list.add(new userinfo(1,"c",formater.parse("1980-10-01"),30)); list.add(new userinfo(2,"a",formater.parse("1973-10-01"),11)); system.out.println("-------原来序列-------------------"); for(userinfo user : list){ system.out.println(user.tostring()); } //调用排序通用类 sortlist<userinfo> sortlist = new sortlist<userinfo>(); //按userid排序 sortlist.sort(list, "getuserid", "desc"); system.out.println("--------按userid倒序------------------"); for(userinfo user : list){ system.out.println(user.tostring()); } //按username排序 sortlist.sort(list, "getusername", null); system.out.println("---------按username排序-----------------"); for(userinfo user : list){ system.out.println(user.tostring()); } //按birthdate排序 sortlist.sort(list, "getbirthdatestr", null); system.out.println("---------按birthdate排序-----------------"); for(userinfo user : list){ system.out.println(user.tostring()); } } }
测试结果如下:
-------原来序列------------------- 3; b; 1980-12-01; 11 1; c; 1980-10-01; 30 2; a; 1973-10-01; 11 --------按userid倒序------------------ 3; b; 1980-12-01; 11 2; a; 1973-10-01; 11 1; c; 1980-10-01; 30 ---------按username排序----------------- 2; a; 1973-10-01; 11 3; b; 1980-12-01; 11 1; c; 1980-10-01; 30 ---------按birthdate排序----------------- 2; a; 1973-10-01; 11 1; c; 1980-10-01; 30 3; b; 1980-12-01; 11
注意:日期的排序是先通过格式转换再来排序的,否则将不能有正确的结果。
希望本文所述对大家的java程序设计有所帮助。
上一篇: python学习--SQLAlchemy
下一篇: PHP 接入微信扫码支付总结(总结篇)