• 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