How java programs interact with virtual machines at the microarchitectural level
OOPSLA '03 Proceedings of the 18th annual ACM SIGPLAN conference on Object-oriented programing, systems, languages, and applications
Hi-index | 0.00 |
Mobile Runtime Environments such as Java*2 Micro Edition (J2ME*) and Microsoft WinCE.NET* Compact Framework* are becoming standard managed application execution environments on memory constrained devices. A variety of implementations exists, and so too are a variety of systems they could run on, and finally a variety of workloads. It becomes important to understand how they compare.In this paper we describe comparative performance analysis of mobile runtimes on products with Intel XScale® micro-architecture. We were interested in a number of comparisons. These include CLDC vs. CDC workloads, Interpreters vs. JIT compilers, and J2ME vs. Native applications. In addition we compare runtimes when memory subsystem improves and MHz varies.We find that when comparing how mobile runtimes utilize the underlying micro-architecture, multiple implementations have similar stall analysis. We find that JIT (Just-In-Time) compilers are about 4-6 times faster than interpreters. For a class of applications we measured, J2ME apps were about two times slower than their C counterparts. We find that memory subsystem improvements have minor impact on interpreters but have much more impact on JIT compilers.