A large scale empirical study of the impact of Spaghetti Code and Blob anti-patterns on program comprehension

Saved in:
Bibliographic Details
Title: A large scale empirical study of the impact of Spaghetti Code and Blob anti-patterns on program comprehension
Authors: Politowski, Cristiano, Khomh, Foutse, Romano, Simone, Scanniello, Giuseppe, Petrillo, Fabio, Guéhéneuc, Yann-Gaël, Maiga, Abdou
Publication Year: 2020
Collection: Université du Québec à Chicoutimi (UQAC): Constellation
Subject Terms: Informatique, anti-patterns, blob, Spaghetti code, program comprehension, Java
Description: Context Several studies investigated the impact of anti-patterns (i.e., “poor” solutions to recurring design problems) during maintenance activities and reported that anti-patterns significantly affect the developers’ effort required to edit files. However, before developers edit files, they must understand the source code of the systems. This source code must be easy to understand by developers. Objective In this work, we provide a complete assessment of the impact of two instances of two anti-patterns, Blob or Spaghetti Code, on program comprehension. Method We analyze the impact of these two anti-patterns through three empirical studies conducted at Polytechnique Montré al (Canada) with 24 participants; at Carlton University (Canada) with 30 participants; and at University Basilicata (Italy) with 79 participants. Results We collect data from 372 tasks obtained thanks to 133 different participants from the three universities. We use three metrics to assess the developers’ comprehension of the source code: (1) the duration to complete each task; (2) their percentage of correct answers; and, (3) the NASA task load index for their effort. Conclusions We report that, although single occurrences of Blob or Spaghetti code anti-patterns have little effect on code comprehension, two occurrences of either Blob or Spaghetti Code significantly increases the developers’ time spent in their tasks, reduce their percentage of correct answers, and increase their effort. Hence, we recommend that developers act on both anti-patterns, which should be refactored out of the source code whenever possible. We also recommend further studies on combinations of anti-patterns rather than on single anti-patterns one at a time.
Document Type: article in journal/newspaper
File Description: application/pdf
Language: English
Relation: https://constellation.uqac.ca/id/eprint/6227/; http://dx.doi.org/doi:10.1016/j.infsof.2020.106278; https://constellation.uqac.ca/id/eprint/6227/1/2020Politowski.pdf
DOI: 10.1016/j.infsof.2020.106278
Availability: https://constellation.uqac.ca/id/eprint/6227/1/2020Politowski.pdf
https://doi.org/10.1016/j.infsof.2020.106278
Rights: cc_by_nc_nd
Accession Number: edsbas.8AD945
Database: BASE
Description
Abstract:Context Several studies investigated the impact of anti-patterns (i.e., “poor” solutions to recurring design problems) during maintenance activities and reported that anti-patterns significantly affect the developers’ effort required to edit files. However, before developers edit files, they must understand the source code of the systems. This source code must be easy to understand by developers. Objective In this work, we provide a complete assessment of the impact of two instances of two anti-patterns, Blob or Spaghetti Code, on program comprehension. Method We analyze the impact of these two anti-patterns through three empirical studies conducted at Polytechnique Montré al (Canada) with 24 participants; at Carlton University (Canada) with 30 participants; and at University Basilicata (Italy) with 79 participants. Results We collect data from 372 tasks obtained thanks to 133 different participants from the three universities. We use three metrics to assess the developers’ comprehension of the source code: (1) the duration to complete each task; (2) their percentage of correct answers; and, (3) the NASA task load index for their effort. Conclusions We report that, although single occurrences of Blob or Spaghetti code anti-patterns have little effect on code comprehension, two occurrences of either Blob or Spaghetti Code significantly increases the developers’ time spent in their tasks, reduce their percentage of correct answers, and increase their effort. Hence, we recommend that developers act on both anti-patterns, which should be refactored out of the source code whenever possible. We also recommend further studies on combinations of anti-patterns rather than on single anti-patterns one at a time.
DOI:10.1016/j.infsof.2020.106278