Java實現ArrayList排序的方法詳解
簡介
說明
本文用示例介紹Java的ArrayList排序的方法。
List排序方法
主要有三種方法(按推薦度排序):
- JDK8的stream
- Comparator#compare()
- Comparable#compareTo()
法1:JDK8的stream
見:一文詳解Java中Stream流的使用
法2:Comparator#compare()
需求:用戶有成績和年齡。按成績排序,若成績相同,則按年齡排序。
package org.example.a; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; class User{ private int score; private int age; public User(int score, int age){ super(); this.score = score; this.age = age; } public int getScore() { return score; } public void setScore(int score) { this.score = score; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } } public class Demo { public static void main(String[] args) { List<User> users = new ArrayList<User>(); users.add(new User(95, 26)); users.add(new User(84, 23)); users.add(new User(96, 25)); users.add(new User(95, 24)); Collections.sort(users, new Comparator<User>() { @Override public int compare(User o1, User o2) { int i = o2.getScore() - o1.getScore(); if(i == 0){ return o1.getAge() - o2.getAge(); } return i; } }); for(User user : users){ System.out.println(user.getScore() + "," + user.getAge()); } } }
執行結果
96,25
95,24
95,26
84,23
法3:Comparable#compareTo()
默認按增序排序:
package org.example.a; import java.util.ArrayList; import java.util.Collections; import java.util.List; public class Demo { public static void main(String[] args) { List<Integer> nums = new ArrayList<Integer>(); nums.add(3); nums.add(5); nums.add(1); nums.add(0); System.out.println(nums); Collections.sort(nums); System.out.println(nums); } }
執行結果:
[3, 5, 1, 0]
[0, 1, 3, 5]
需求:用戶有成績和年齡。按成績降序排序,若成績相同,則按年齡正序排序。
package org.example.a; import java.util.ArrayList; import java.util.Collections; import java.util.List; class User implements Comparable<User>{ private int score; private int age; public User(int score, int age){ super(); this.score = score; this.age = age; } public int getScore() { return score; } public void setScore(int score) { this.score = score; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public int compareTo(User o) { int i = o.getScore() - this.getScore(); if(i == 0){ return this.getAge() - o.getAge(); } return i; } } public class Demo { public static void main(String[] args) { List<User> users = new ArrayList<User>(); users.add(new User(95, 26)); users.add(new User(84, 23)); users.add(new User(96, 25)); users.add(new User(95, 24)); Collections.sort(users); for(User user : users){ System.out.println(user.getScore() + "," + user.getAge()); } } }
執行結果
96,25
95,24
95,26
84,23
到此這篇關於Java實現ArrayList排序的方法詳解的文章就介紹到這瞭,更多相關Java ArrayList排序內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- java中ArrayList的兩種排序方法實例
- Java List的sort()方法改寫compare()實現升序,降序,倒序的案例
- java Comparator.comparing排序使用示例
- java集合進行排序的方式總結
- 基於list stream: reduce的使用實例