An Analysis of Programming Language Statement Frequency in C, C++, and Java Source Code

Xiaoyan Zhu,E. James Whitehead,Caitlin Sadowski,Qinbao Song
DOI: https://doi.org/10.1002/spe.2298
2014-01-01
Software Practice and Experience
Abstract:SummaryStatement frequency data can inform programming language research and provide a solid basis for frequency‐based code analysis. This paper presents an analysis of programming language statement frequency in a large corpus of C, C++, and Java source code, comprised of more than 54 million lines of code. Across these languages, the top four work‐performing statement types are Method/Function Call, Assignment, If, and Return. As compared to studies of Formula Translating System, Common Business Oriented Language and Programming Language One in the 1970s, the main change is the prevalence of method/function calls. Statement use frequency across languages is remarkably similar, and within each individual language, most statement types have a frequency distribution that occupies a small range. A more detailed examination of assignment and looping statement types shows that many assignments simply involve copying of data and that C++/Java use for statements more than C. Copyright © 2014 John Wiley & Sons, Ltd.
What problem does this paper attempt to address?