An Empirical Study of goto in C Code from GitHub Repositories

Authors - Meiyappan Nagappan, Romain Robbes, Yasutaka Kamei, Éric Tanter, Shane McIntosh, Audris Mockus, Ahmed E. Hassan
Venue - Joint meeting of the European Software Engineering Conference and the International Symposium on the Foundations of Software Engineering, pp. 404-414, 2015

Related Tags - FSE 2015 software quality

Abstract - It is nearly 50 years since Dijkstra argued that goto obscures the flow of control in program execution and urged programmers to abandon the goto statement. While past research has shown that goto is still in use, little is known about whether goto is used in the unrestricted manner that Dijkstra feared, and if it is 'harmful' enough to be a part of a post-release bug. We, therefore, conduct a two part empirical study: (1) qualitatively analyze a statistically representative sample of 384 files from a population of almost 2 million C programming language files collected from over 11K GitHub repositories and find that developers use goto in C files for error handling (80.21 ± 5%) and cleaning up resources at the end of a procedure (40.36 ± 5%); and (2) quantitatively analyze the commit history from the release branches of six OSS projects and find that no goto statement was removed/modified in the post-release phase of four of the six projects. We conclude that developers limit themselves to using goto appropriately in most cases, and not in an unrestricted manner like Dijkstra feared, thus suggesting that goto does not appear to be harmful in practice.

Preprint - PDF

Bibtex

@inproceedings{nagappan2015fse,
  Author = {Meiyappan Nagappan and Romain Robbes and Yasutaka Kamei and Éric Tanter and Shane McIntosh and Audris Mockus and Ahmed E. Hassan},
  Title = {{An Empirical Study of goto in C Code from GitHub Repositories}},
  Year = {2015},
  Booktitle = {Proc. of the Joint meeting of the European Software Engineering Conference and the International Symposium on the Foundations of Software Engineering (FSE)},
  Pages = {404-414}
}