сортировка java с использованием анонимного класса

У меня есть класс, в котором я сортирую список.

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);
   }

}


}

После запуска программы я получаю следующие значения:

1    
third
first
second
2
fourth

Мой вопрос заключается в том, как ведет себя здесь функция Collection.sort(). При возврате -1 из функции сравнения мы получаем обратный порядок списка. Тогда как мы можем получить другие порядки сортировки? Какова роль возврата 0 и 1?

10
задан DJClayworth 3 July 2015 в 13:30
поделиться