• 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