A quantitative analysis of OS noise
Alessandro Morari, Roberto Gioiosa, et al.
IPDPS 2011
The Java™ language specification requires that all array references be checked for validity. If a reference is invalid, an exception must be thrown. Furthermore, the environment at the time of the exception must be preserved and made available to whatever code handles the exception. Performing the checks at run time incurs a large penalty in execution time. In this paper we describe a collection of transformations that can dramatically reduce this overhead in the common case (when the access is valid) while preserving the program state at the time of an exception. The transformations allow trade-offs to be made in the efficiency and size of the resulting code, and are fully compliant with the Java language semantics. Preliminary evaluation of the effectiveness of these transformations shows that performance improvements of 10 times and more can be achieved for array-intensive Java programs.
Alessandro Morari, Roberto Gioiosa, et al.
IPDPS 2011
John M. Boyer, Charles F. Wiecha
DocEng 2009
Israel Cidon, Leonidas Georgiadis, et al.
IEEE/ACM Transactions on Networking
Daniel M. Bikel, Vittorio Castelli
ACL 2008