DocumentCode :
2893917
Title :
Checkmate: A Generic Static Analyzer of Java Multithreaded Programs
Author :
Ferrara, Pietro
Author_Institution :
ETH Zurich, Zurich, Switzerland
fYear :
2009
fDate :
23-27 Nov. 2009
Firstpage :
169
Lastpage :
178
Abstract :
In this paper we present Checkmate, a generic static analyzer of Java multithreaded programs based on the abstract interpretation theory. It supports all the most relevant features of Java multithreading, as dynamic unbounded thread creation, runtime creation of monitors, and dynamic allocation of shared memory. We implement a wide set of properties, from the ones interesting also for sequential programs, e.g. division by zero, to the ones typical of multithtreaded programs, e.g. data races. We analyze several external case studies and benchmarks with Checkmate, and we study the experimental results both in term of precision and efficiency. It turns out that the analysis is particularly accurate and we are in position to analyze programs composed by some thousands of statements and a potentially infinite number of threads. As far as we know, Checkmate is the first generic static analyzer of Java multithreaded programs.
Keywords :
Java; distributed shared memory systems; multi-threading; program diagnostics; resource allocation; Checkmate; Java multithreaded programs; Java multithreading; abstract interpretation theory; dynamic allocation; dynamic unbounded thread creation; generic static analyzer; runtime creation; sequential programs; shared memory; Java; Abstract Interpretation; Multithreaded Programs; Static Analysis;
fLanguage :
English
Publisher :
ieee
Conference_Titel :
Software Engineering and Formal Methods, 2009 Seventh IEEE International Conference on
Conference_Location :
Hanoi
Print_ISBN :
978-0-7695-3870-9
Type :
conf
DOI :
10.1109/SEFM.2009.20
Filename :
5368098
Link To Document :
بازگشت