本篇內(nèi)容主要講解“Java 中 Collections.sort()的應(yīng)用方法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java 中 Collections.sort()的應(yīng)用方法”吧!
在昌都等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計 網(wǎng)站設(shè)計制作定制網(wǎng)站建設(shè),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),營銷型網(wǎng)站建設(shè),外貿(mào)營銷網(wǎng)站建設(shè),昌都網(wǎng)站建設(shè)費用合理。
關(guān)于 Java 中 Collections.sort()方法 的使用<comparable 、 compareTo>
例如
public static void main(String[] args) { List<String> list = new ArrayList<String>(); list.add("abc"); list.add("abb"); list.add("bcd"); Collections.sort(list,new Comparator<String>() { @Override public int compare(String o1, String o2) { /** 升序排序是 第一個參數(shù).compareTo(第二個參數(shù)); 降序排序是 第二個參數(shù).compareTo(第一個參數(shù)); */ return o2.compareTo(o1); } }); System.out.println(list); }
輸出: [bcd, abc, abb]
第一種:Comparable 排序接口
如果一個類實現(xiàn)了Comparable接口,就意味著"該類支持排序"。
實現(xiàn)Comparable接口,重寫compareTo()方法實現(xiàn)排序
/* User實體類 */ public class User implements Comparable<User>{ private int id; private String name; private int age; public User(){} public User(int id, String name, int age) { super(); this.id = id; this.name = name; this.age = age; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public int compareTo(User u) { // 按age排序,也可按照其他成員變量排序 return this.age - u.getAge(); // 升序 // return u.getAge() - this.age; //降序 } @Override public String toString() { return "User [id=" + id + ", name=" + name + ", age=" + age + "]"; } } /* Test測試類 */ ublic class Test { public static void main(String[] args) { List<User> list = new ArrayList<User>(); User user1 = new User(1,"aaaa",14); User user2 = new User(2,"bbbb",21); User user3 = new User(3,"cccc",12); User user4 = new User(4,"dddd",16); User user5 = new User(5,"eeee",9); list.add(user1); list.add(user2); list.add(user3); list.add(user4); list.add(user5); /* list中的對象User實現(xiàn)了Comparable接口,含有compareTo()方法, 所以可以直接調(diào)用Collections.sort()方法進行排序 */ Collections.sort(list); System.out.println(list); } }
輸出結(jié)果:[User [id=5, name=eeee, age=9], User [id=3, name=cccc, age=12], User [id=1, name=aaaa, age=14], User [id=4, name=dddd, age=16], User [id=2, name=bbbb, age=21]]
第二種:Comparator比較器接口
如果我們需要對某個類排序,但該類本身不支持排序(即沒有實現(xiàn)Comparable接口),可使用Comparator比較器接口。
實體類不用實現(xiàn)Comparable接口
/* User實體類 */ public class User{ private int id; private String name; private int age; public User(){} public User(int id, String name, int age) { super(); this.id = id; this.name = name; this.age = age; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User [id=" + id + ", name=" + name + ", age=" + age + "]"; } } /* Test測試類 */ public class Test { public static void main(String[] args) { List<User> list = new ArrayList<User>(); User user1 = new User(1,"aaaa",14); User user2 = new User(2,"bbbb",21); User user3 = new User(3,"cccc",12); User user4 = new User(4,"dddd",16); User user5 = new User(5,"eeee",9); list.add(user1); list.add(user2); list.add(user3); list.add(user4); list.add(user5); /* list中的對象User沒有實現(xiàn)了Comparable接口, 通過重載Collections.sort()方法實現(xiàn)排序 */ Collections.sort(list,new Comparator<User>() { @Override public int compare(User u1, User u2) { //return u2.getAge()-u1.getAge(); // 降序 // return u1.getAge()-u2.getAge(); // 升序 return u2.getName().compareTo(u1.getName()); // 名字降序 } }); System.out.println(list); } }
輸出結(jié)果:[User [id=5, name=eeee, age=9], User [id=4, name=dddd, age=16], User [id=3, name=cccc, age=12], User [id=2, name=bbbb, age=21], User [id=1, name=aaaa, age=14]]
總結(jié):前者代碼結(jié)構(gòu)簡單,但是只能根據(jù)固定的屬性排序; 后者靈活,可以臨時指定排序項,但是代碼不夠簡潔
到此,相信大家對“Java 中 Collections.sort()的應(yīng)用方法”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!
當前標題:Java中Collections.sort()的應(yīng)用方法
網(wǎng)站地址:http://m.rwnh.cn/article34/jipepe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、關(guān)鍵詞優(yōu)化、品牌網(wǎng)站制作、標簽優(yōu)化、做網(wǎng)站、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)