views:

252

answers:

3

Over time, Sun's JVM and JIT have gotten pretty smart. Things that used to be common knowledge as being a necessary micro-optimization are no longer needed, because it gets taken care of for you.

For example, it used to be the case that you should mark all possible classes as final, so the JVM inlines as much code as possible. However now, the JIT knows whether your class is final based on what classes get loaded in at runtime, and if you load a class to make the original one non-final-able, it un-inlines the methods and un-marks it as final.

What other smart micro-optimizations does the JVM or JIT do for you?

EDIT: I made this a community wiki; I'd like to collect these over time. I am really surprised more people are not interested in this.

+3  A: 

It's beyond impressive. All of these are things you can't do in C++ (certainly to the same extent Java does). Keep in mind that early versions of Java started the "slow" reputation by not having these things, and we keep improving significantly over time. This is still a big research area.

280Z28
well java might be smart but it still uses alot of ressources
mnml
@mnml it's less than what the popular opinion is. to create an object i think they have it down to something like 2 or 3 instructions. yes something like C++ is generally faster, but 'resources' isn't just CPU and memory; it's man hours too. hardware is cheap, people are expensive. over the long term, java will often win out in performance because its JIT is amazing and will optimize the app more than most C++ apps could ever dream of.
Alex Beardsley
+2  A: 

Java is smarter at inlining as it can

  • inline code only available at runtime or even dynamically generated.
  • inline virtual methods (up to two at once)
  • perform escape analysis on inlined methods and the methods they were inlined to. (Much harder to do in C++)
Peter Lawrey
+2  A: 

http://wikis.sun.com/display/HotSpotInternals/PerformanceTechniques

bkail
Wow, this is really great.
Alex Beardsley