您好,登錄后才能下訂單哦!
一、集合排序概述
1、主要內(nèi)容
回顧:
//數(shù)組的排序 int[] arr= {2,3,4,5,2,1}; Arrays.sort(arr);
2、集合排序方法
二、對基本數(shù)據(jù)類型和字符串類型進行排序
1、對基本數(shù)據(jù)類型排序
List中只能存放對象,要想存放基本數(shù)據(jù)類型的話,泛型中只能寫其對應的包裝類。
import java.util.ArrayList; import java.util.Collections; import java.util.List; public class IntSort { public static void main(String[] args) { //對存儲在List中的整形數(shù)據(jù)進行排序 List<Integer> list = new ArrayList<Integer>(); list.add(5); list.add(9); list.add(3); list.add(1); System.out.println("排序前:"); for (int n: list) { System.out.print(n + " "); } System.out.println(); //對List中的數(shù)據(jù)進行排序 Collections.sort(list); System.out.println("排序后:"); for (int n: list) { System.out.print(n + " "); } } }
2、對字符串排序
集合中字符串的排序后其實是按字符順序,ASCII值順序進行排序的
import java.util.ArrayList; import java.util.Collections; import java.util.List; public class StringSort { public static void main(String[] args) { //對存放在List中的字符串進行排序。 List<String> list = new ArrayList<String>(); list.add("orange"); list.add("blue"); list.add("yellow"); list.add("gray"); System.out.println("排序前: "); for (String str: list) { System.out.print(str + " "); } System.out.println(); //對List中的數(shù)據(jù)進行排序 Collections.sort(list); System.out.println("排序后: "); for (String str: list) { System.out.print(str + " "); } //排序后其實是按字母順序 } }
三、Comparator接口
1、問題場景:
自定義的類如何排序?
2、解決方法:
使用Comparable或Comparator接口
3、Comparator接口介紹
4、對寵物貓進行排序
對自定義的類按照一定的規(guī)則進行排序:
(1)對寵物貓按名字進行排序
String類型具有compareTo()方法
例:
int n = name1.conpareTo(name2);
如果name1<name2時,那么n是負整數(shù),相等則為0,否則為正整數(shù)。
name1與name2位置調換下,則會實現(xiàn)倒序的排序。
import java.util.Comparator; //按名字進行升序排序的比較器 public class NameComparator implements Comparator<Cat> { @Override public int compare(Cat o1, Cat o2) { //按名字升序排序 String name1 = o1.getName(); String name2 = o2.getName(); int n = name1.compareTo(name2); return n; } }
語法格式:
Collections.sort(catList, new NameComparator());
(2)對寵物貓按年齡降序排序
import java.util.Comparator; //按年齡進行降序排序的比較器 public class AgeComparator implements Comparator<Cat> { @Override public int compare(Cat o1, Cat o2) { int age1 = o1.getMonth(); int age2 = o2.getMonth(); return age2 - age1; } }
語法格式:
Collections.sort(catList, new AgeComparator());
四、Comparable接口
1、Comparable概述
2、對商品價格進行降序排序案例
(1)操作步驟
(2)代碼實現(xiàn)
①商品類的定義
public class Goods implements Comparable<Goods> { //實現(xiàn)Comparable接口,利用泛型限定比較的類型 private String id; //商品編號 private String name; //商品名稱 private double price; //商品價格 //構造方法 public Goods() { } public Goods(String id, String name, double price) { this.setId(id); this.setName(name); this.setPrice(price); } //getter和setter方法 public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public double getPrice() { return price; } public void setPrice(double price) { this.price = price; } @Override public String toString() { return "商品編號:" + id + ",商品名稱:" + name + ",商品價格:" + price; } @Override public int compareTo(Goods o) { //重寫compareTo方法。 //取出商品價格 double price1 = this.getPrice(); double price2 = o.getPrice(); int n = new Double(price2 - price1).intValue(); //double類型的差值轉為int return n; }
②排序步驟
Collections.sort(goodsList);
五、集合排序總結
Comparator和Comparable接口的區(qū)別
1、Comparator:
①位于java.util包
②在要比較的類的外部實現(xiàn)該接口
③調用sort方法時,要指定Comparator的實現(xiàn)類
使用順序:
2、Comparable
①位于java.lang包
②在要比較的類上實現(xiàn)該接口
③調用sort方法時,只需指定集合名即可
使用順序:
定義要比較的類,并實現(xiàn)comparable接口
測試
以上所述是小編給大家介紹的Java集合排序詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。