Dynamic Languages on the JVM
JRuby lead developer Charles Oliver Nutter:
I believe we’re pretty well on-target to have the [JRuby-to-JVM-bytecode] compiler completed by RubyConf in November. […] Once the JRuby compiler is complete, we will start testing in earnest against a fully pre-compiled Ruby stdlib. Along with that, we’ll wire in support for pre-compiling RubyGems as they install and pre-compiling Ruby scripts as they are executed and loaded. Much of this works already in prototype form, but it waits for the completion of the compiler to go into general use.
I also have plans for a “static” compiler for JRuby that enable compiling Ruby classes into normal, instantiable, callable, static Java classes. This would bring us on par with other compiled languages on the JVM, and allow you to directly instantiate and invoke JRuby/Ruby objects from within your Java code.
Peter Knego wonders “Why Is Groovy So Slow?” and shows some evidence. I will admit I expected Groovy to be slower than Java because even though it does compile to Java byte codes. It has to perform various translations to satisfy the VM that expects a lot to be already typed. The Java VM is an ugly world for dynamic languages because of the early bind nature to gain performance. Some of his numbers were shocking. He also mentioned he was going to run numbers on jRuby as well. I’ll be curious about that too. I’m expecting the numbers to tell a similar story. […] The numbers are not bad because dynamic languages are slow, but because trying to get them run on an architecture not built with them in mind.