In Java6 both quicksort and mergesort were used in Arrays#sort
, for primitive and object arrays respectively. In Java7 these have both changed, to DualPivotQuicksort and Timsort.
In the source for the new quicksort, the following comment appears in a couple of places (eg line 354):
/* * Here and below we use "a[i] = b; i++;" instead * of "a[i++] = b;" due to performance issue. */
How is this a performance issue? Won't the compiler will reduce these to the same thing?
More broadly, what is a good strategy for investigating this myself? I can run benchmarks, but I'd be more interested in analysing any differences in the compiled code. However, I don't know what tools to use etc.
This is only an answer to the general question.
You can look at the bytecode and try to understand the differences. I.e. you could write yourself a simple example using both a[i] = b; i++;
and a[i++] = b;
and see whats the difference.
The simplest way to show the bytecode is the javap
program (should be included in you JDK). Compile the code with javac SomeFile.java
and run javap on the code: javap -c SomeFile
(the -c switch tells javap to output the bytecode for each method in the file).
If you are using eclipse you could also try this one.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With