Accédez directement au code :
importer java.util.ArrayList; importer java.util.Collections; importer java.util.Comparator; importer java.util.List;/** * * <p> * ClassName CollectionsSort * </p> * <p> * Description Introduit principalement deux algorithmes de tri pour les collections<br/> * Premièrement : java.util.Collections.sort(java.util.List), qui nécessite que les éléments triés implémentent l'interface java.lang.Comparable<br/> * Deuxièmement : java.util.Collections.sort(java.util.List, java.util.Comparator), cette méthode nécessite l'implémentation de l'interface java.util.Comparator<br/> * Troisième : L'exemple suivant utilise l'attribut int Type tri, vous pouvez utiliser les méthodes suivantes pour trier les attributs de chaîne<br/> * public int compareTo(Cat o){return this.getName().compareTo(o.getName(0);}<br/> * Quatrième : Description de la fonction compareTo()<br/> * Si résultat ;<br/> * <0 a<b;<br/>= * ==0 a==b;<br/> * >=0 a >b; * </p> * * @auteur wangxu [email protected] * <p> * Date 2014-9-16 04:52:57 PM * </p> * @version V1.0 * */public class CollectionsSort {public static void main(String[] args) {// method1(); tester la première méthode method2(); // tester la deuxième méthode} public static void method1() {List<Cat > list = new ArrayList<Cat>();Cat c = new Cat("a", 10);list.add(c);c = new Cat("b", 20);list.add(c);c = new Cat("c", 3);list.add(c);// Trier la sortie par ordre croissant Collections.sort(list);System.out.println( list); // Trie la sortie par ordre décroissant Collections.sort(list, Collections.reverseOrder());System.out.println(list);} public static void method2() {List<Cat> list = new ArrayList<Cat>();Cat c = new Cat("a", 10);list.add(c);c = new Cat("b", 20);list.add(c);c = new Cat ("c", 3);list.add(c);Comparator<Cat> catComparator = new Cat();//Sortie par ordre croissant Collections.sort(list, catComparator);System.out.println(list);// Trier la sortie par ordre décroissant catComparator = Collections.reverseOrder(catComparator);Collections.sort(list, catComparator);System.out.println(list);}}class Cat implémente Comparable <Cat>, Comparator<Cat> {private int age;private String name;public Cat() {}public Cat(String name, int age) {this.age = age;this.name = name;}public int getAge() {return this.age;}public String getName() {return this.name;}public void setAge(int age) {this.age = age;}public void setName(String name) {this.name = name;}// Implémente l'interface Comparable, ne remplacez pas cette méthode @Overridepublic int compareTo(Cat o) {// TODO Méthode générée automatiquement stubreturn this.age - o.age;}@Overridepublic String toString() {// TODO Méthode générée automatiquement stubreturn "Name : " + getName() + ",Age : " + getAge();}// Interface de comparaison implémentée , vous devez remplacer cette méthode @Overridepublic int compare(Cat o1, Cat o2) {// TODO Méthode générée automatiquement stubreturn o1.getAge() - o2.getAge();}}