We found a match
Your institution may have access to this item. Find your institution then sign in to continue.
- Title
A study and toolkit of CHECK-THEN-ACT idioms of Java concurrent collections.
- Authors
Lin, Yu; Dig, Danny
- Abstract
Concurrent collections are widely used in concurrent programs. However, programmers can misuse these concurrent collections when composing two operations where a check on the collection (e.g., collection contains an element) precedes an action (e.g., inserting an element). Unless the whole composition is atomic, the program contains an atomicity violation bug. This paper presents an extensive empirical study of CHECK-THEN-ACT idioms of Java (Oracle Corporation, Redwood, CA, USA) concurrent collections. We analyze 28 widely used open-source Java projects (comprising 6.4 million lines of code) that use Java concurrent collections. We study the correct and incorrect use of idioms and the evolution of the programs with respect to idioms. Our tool, CTADETECTOR, detects and corrects misused idioms. CTADETECTOR discovered 60 bugs that were confirmed and fixed by developers. This shows that CHECK-THEN-ACT idioms are commonly misused in practice, and correcting them is important. Copyright © 2015 John Wiley & Sons, Ltd.
- Subjects
JAVA programming language; CONCURRENT error detection; THREADS (Computer programs); IDIOMS; COMPUTER programmers
- Publication
Software Testing: Verification & Reliability, 2015, Vol 25, Issue 4, p397
- ISSN
0960-0833
- Publication type
Article
- DOI
10.1002/stvr.1567