第一個是list中的物件實作Comparable接口,如下:
/*** 依order對User排序*/public class User Implements Comparable <user> { private String name;私有整數訂單;公有字串 getName() { 傳回名稱; } public void setName(String name) { this.name = name; } public Integer getOrder() { 回傳訂單; } public void setOrder(Integer order) { this.order = order; } public intcompareTo(User arg0) { return this.getOrder().compareTo(arg0.getOrder()); }} </用戶>
測試一下:
public class Test{ public static void main(String[] args) { 使用者 user1 = new User(); user1.setName("a"); user1.setOrder(1);使用者 user2 = new User(); user2.setName("b"); user2.setOrder(2); List<用戶> list = new ArrayList<用戶>(); //此處新增user2再加入user1 list.add(user2);列表.add(user1); Collections.sort(列表); for(用戶 u : 列表){ System.out.println(u.getName()); } }} </用戶> </用戶>
輸出結果如下
一個
乙
第二個方法是根據Collections.sort重載方法來實現,例如:
/*** 依照order對User排序*/public class User { //此處消耗實作Comparable介面 private String name;私有整數訂單;公有字串 getName() { 傳回名稱; } public void setName(String name) { this.name = name; } public Integer getOrder() { 回傳訂單; } public void setOrder(Integer order) { this.order = order; }}
主類別這樣寫即可:
public class Test{ public static void main(String[] args) { 使用者 user1 = new User(); user1.setName("a"); user1.setOrder(1);使用者 user2 = new User(); user2.setName("b"); user2.setOrder(2); List<用戶> list = new ArrayList<用戶>();列表.add(user2);列表.add(user1); Collections.sort(list,new Comparator <user> (){ public int Compare(User arg0, User arg1) { return arg0.getOrder().compareTo(arg1.getOrder()); } }); for(用戶 u : 列表){ System.out.println(u.getName()); } }} </用戶> </用戶> </用戶>
輸出結果如下
一個
乙
上面程式碼結構簡單,但只能依照固定的屬性排序,晚上高效,可以臨時排序指定項,但是程式碼不夠簡潔
多領域的場合:
Collections.sort(list,new Comparator <user> (){ public int Compare(User arg0, User arg1) { // 第一次比較專業 int i = arg0.getOrder().compareTo(arg1.getOrder()); // 如果專業相同則進行第二次比較if(i==0){// 第二次比較int j=arg0.getXXX().compareTo(arg1.getXXX());// 如果學制相同則傳回依年齡排序if(j==0){ return arg0.getCCC().compareTo(arg1.getCCC()); } return j; } return i; </用戶>
以上內容就是小編跟大家介紹有關用Java集合中的Collections.sort方法如何對列表排序(兩種方法),希望對大家有幫助。