To be clear, I am trying to find out how Collections.sort(list, new MyComp()) method calls the compare method in which sequence.
I have a LinkedList with Employees a
Collections.sort's sorting algorithm in Java 7 is insertion sort.
The specific comparisons made depend on what algorithm, internally, the Collections.sort
method is using to sort the elements. According to the Javadoc for Collections.sort
:
The documentation for the polymorphic algorithms contained in this class generally includes a brief description of the implementation. Such descriptions should be regarded as implementation notes, rather than parts of the specification. Implementors should feel free to substitute other algorithms, so long as the specification itself is adhered to. (For example, the algorithm used by sort does not have to be a mergesort, but it does have to be stable.)
In other words, Java implementations are free to use whatever sorting algorithm they'd like, provided that it keeps equal elements in the same relative order. This means that without more knowledge of your specific Java implementation, there's no way to know what comparisons are going to be made. (If I remember correctly, the Oracle version of Java actually switched its implementation of Collections.sort
from Java 7 to Java 8, though I may be mistaken.)
That said, that's not a bad thing. The idea behind writing a comparator is to tell the sorting method "do whatever you need to do to sort things, and if you ever need to make a comparison, here's the way to do it." It's a nice abstraction - you say how to rank things, and the Magic Black Box of Sorting then goes and uses it to get things into order.