Si ta classe Java qui doit être triée est toujours triée de la même manière, tu peux utiliser l'interface comparable.
Celle-ci est à rattacher directement à ta classe java à trier.
Si ta classe implémente cette interface, les méthodes de tri (Collections.sort(l)

Java s'appuieront sur la méthode compareTo implémentée de cette interface pour réaliser le tri.
Si par contre, tu as besoin d'avoir différents types de tris pour une même classe : croissant, décroissant, dans un cas avec tels attributs dans un autre cas avec tels autres attributs... il te faut travailler avec l'interface comparator.
Dans ce cas, ton interface n'est pas directement rattachée à ta classe. Il te faut créer une nouvelle classe (ou n nouvelles classes) qui implémente l'interface comparator.
Quand tu auras besoin de faire un tri, tu devras en plus de fournir la liste contenant tes classes à trier fournir ta classe implémentant le comparator (Collections.sort(l,
classeComparator)

.
Suivant le type de tri réalisé, tu utiliseras la classe réalisant la comparaison correspondante.
Arnaud
Partager