@article{JendroschDueckGracieetal.2014, author = {Manfred Jendrosch and Gerhard W. Dueck and Charlie Gracie and Andr{\´e} Hinkenjann}, title = {PC Based Escape Analysis in the Java Virtual Machine}, series = {LNSE (Lecture Notes on Software Engineering)}, volume = {2}, number = {1}, issn = {2301-3559}, doi = {10.7763/LNSE.2014.V2.87}, pages = {16 -- 20}, year = {2014}, abstract = {Current computer architectures are multi-threaded and make use of multiple CPU cores. Most garbage collections policies for the Java Virtual Machine include a stop-the-world phase, which means that all threads are suspended. A considerable portion of the execution time of Java programs is spent in these stop-the-world garbage collections. To improve this behavior, a thread-local allocation and garbage collection that only affects single threads, has been proposed. Unfortunately, only objects that are not accessible by other threads (\"do not escape\") are eligible for this kind of allocation. It is therefore necessary to reliably predict the escaping of objects. The work presented in this paper analyzes the escaping of objects based on the line of code (program counter – PC) the object was allocated at. The results show that on average 60-80\% of the objects do not escape and can therefore be locally allocated.}, language = {en} }