Article ID Journal Published Year Pages File Type
434263 Science of Computer Programming 2014 10 Pages PDF
Abstract

Understanding what happens during the runtime of a Java program is difficult. Tracking runtime flow can bring valuable information for program understanding and behavior analysis. Polymorphism, thread concurrency or even simple facts like the number of method invocations and the number of executed bytecodes are valuable information to track, but are difficult to compute outside the Java Virtual Machine (JVM) on running programs. In this paper, we present JBInsTrace, a new tool that instruments and traces Java bytecode. It produces static information about source code and a very fine grained trace of Java software execution, combining them to allow detailed analysis of the runtime. Our tool differs from others because it does not only trace program classes but also JRE classes, and does so at basic block level, without altering the JVM and without statically modifying class files. We explain JBInsTrace design, focused towards efficiency, which results in reasonable performance penalty.

► JBInsTrace is a new tool that instruments and traces Java bytecode. ► Our technique does not only trace program classes but also JRE classes. ► It does not alter the JVM nor the .class files. ► Tracing is done at the basic block level of granularity. ► It combines static information and trace to allow detailed analysis of the runtime.

Related Topics
Physical Sciences and Engineering Computer Science Computational Theory and Mathematics
Authors
, ,