Search code examples
scalajvmjrockit

Does Scala work well on proprietary JVM's?


My company has a large legacy Java code base and many of our customers run WebSphere and WebLogic. We are considering starting to use Scala but have been unable to confirm that Scala (2.9.X) works well with IBM's JDK (and BEA's JRockit).

Since these JVM's passes the TCK I would say that it should just work, but given the various problems I have had with the different JVM's over the years I am a little nervous. Are there any gotchas to be aware of when using scala with other JVM's ?

  1. Any compiler flags to use (or avoid) ?
  2. Should I compile the code using Scala on hotspot or on the customers JVM ?
  3. Any problems with mixing JAR's compiled using different versions of Scala/Java on different JVM's ?

Any war stories, links and suggestions are welcome.


Solution

  • The Scala compiler should produce the same byte-code regardless of the JVM you use. I would expect Scala to run on all three platforms however HotSpot has tried to optimise for dynamic languages and might be slightly better. (Possibly not enough to worry about)

    In recent years there has been less and less difference between these platforms and in the near future I expect them all to be directly based on OpenJDK (as IBM has agreed to support OpenJDK now) The JRockit and Hotspot teams have been merged for some time since Oracle owns both.

    However if you are not running recent version of the JDK, you may see some issue.

    JVMs talk to each other very well and I would consider running Scala in its own JVM to isolate any concerns you might have.