java-Sortieren mit anonymer Klasse

Habe ich der Klasse, in die ich Sortieren einer Liste.

import java.util.*;

public class First 
{

    private static HashMap<String,Second> msgs;

    public static void main(String[] args) 
    {           

    List<String> ls=new ArrayList<String>();


   ls.add("fourth");
   ls.add("2");
   ls.add("second");
   ls.add("first");
   ls.add("third");
   ls.add("1");

   Iterator it=ls.iterator();

   //before sorting
   while(it.hasNext())
   {
     String s=(String)it.next();
     System.out.println(s);
   }

   Collections.sort(ls, new Comparator(){
       public int compare(Object o1, Object o2) {
           return -1;
           //it can also return 0, and 1
        }
    });

System.out.println(" ");

//after sorting
   Iterator iti=ls.iterator();
   while(iti.hasNext())
   {
     String s=(String)iti.next();

     System.out.println(s);
   }

}


}

Nachdem das Programm auszuführen, bekomme ich diese Werte:

1    
third
first
second
2
fourth

Meine Frage ist, was das Verhalten der Kollektion.Funktion sort() hier. Nach der Rückkehr von -1 Funktion vergleichen, so erhalten wir die umgekehrte Reihenfolge der Liste. Dann, wie können wir andere Reihenfolgen? Was ist die Rolle der Rückgabe von 0 und 1?

  • Was willst du als Ausgabe ?
InformationsquelleAutor Osman Khalid | 2012-05-20
Schreibe einen Kommentar