DocumentCode :
583165
Title :
What Does Control Flow Really Look Like? Eyeballing the Cyclomatic Complexity Metric
Author :
Vinju, Jurgen J. ; Godfrey, Michael W.
Author_Institution :
Centrum Wiskunde & Inf., Amsterdam, Netherlands
fYear :
2012
fDate :
23-24 Sept. 2012
Firstpage :
154
Lastpage :
163
Abstract :
Assessing the understandability of source code remains an elusive yet highly desirable goal for software developers and their managers. While many metrics have been suggested and investigated empirically, the McCabe cyclomatic complexity metric (CC) - which is based on control flow complexity - seems to hold enduring fascination within both industry and the research community despite its known limitations. In this work, we introduce the ideas of Control Flow Patterns (CFPs) and Compressed Control Flow Patterns (CCFPs), which eliminate some repetitive structure from control flow graphs in order to emphasize high-entropy graphs. We examine eight well-known open source Java systems by grouping the CFPs of the methods into equivalence classes, and exploring the results. We observed several surprising outcomes: first, the number of unique CFPs is relatively low, second, CC often does not accurately reflect the intricacies of Java control flow, and third, methods with high CC often have very low entropy, suggesting that they may be relatively easy to understand. These findings challenge the widely-held belief that there is a clear-cut causal relationship between CC and understandability, and suggest that CC and similar measures need to be reconsidered as metrics for code understandability.
Keywords :
Java; entropy; equivalence classes; public domain software; software metrics; Java control flow; McCabe cyclomatic complexity metric; compressed control flow patterns; control flow complexity; control flow graphs; entropy; equivalence classes; high-entropy graphs; open source Java systems; software developers; source code understandability; Abstracts; Complexity theory; Correlation; Java; Measurement; Shape; Syntactics;
fLanguage :
English
Publisher :
ieee
Conference_Titel :
Source Code Analysis and Manipulation (SCAM), 2012 IEEE 12th International Working Conference on
Conference_Location :
Trento
Print_ISBN :
978-1-4673-2398-7
Type :
conf
DOI :
10.1109/SCAM.2012.17
Filename :
6392114
Link To Document :
بازگشت