項目中遇到一個需求:排序
怎麼排呢?以javabean中的日期排序,我首先想到的就是冒泡排序。後來試了一下,麻煩還不好使。
於是,就使用了Java中的Collections.sort方法
具體如下
//把數據進行排序 public void sortData(List<SYSBBZT> filteredData) { Collections.sort(filteredData, new Comparator<SYSBBZT>() { public int compare(SYSBBZT o1, SYSBBZT o2) { //按照截止時間升序排列 if (o1.getBBJZSJ().getTime() > o2.getBBJZSJ().getTime()) { return 1; } if (o1.getBBJZSJ().getTime() == o2.getBBJZSJ().getTime()) { return 0; } return -1; } }); }
簡單介紹下使用,其中的compare方法中有兩個參數(SYSBBZT o1, SYSBBZT o2),這兩個參數就是要去
進行排序比較大小要使用的Javabean的對象。
記住一點,只需要在方法中傳入一個待排序的集合即可。sort方法沒有返回值,表明只需要調用一下這個方法
即可完成排序。 compare方法的返回值爲int類型,其大小表明排序爲升序還是降序。
具體如下:
如果要按照升序排序,則o1.getBBJZSJ().getTime()小於o2.getBBJZSJ().getTime(),返回-1(負數),
相等返回0,o1.getBBJZSJ().getTime()小於o2.getBBJZSJ().getTime(),返回1(正數)
如果要按照降序排序,則o1.getBBJZSJ().getTime()小於o2.getBBJZSJ().getTime(),返回1(正數),
相等返回0,o1.getBBJZSJ().getTime()小於o2.getBBJZSJ().getTime(),返回-1(負數)