Refactoring fat interfaces using a genetic algorithm

Conference Paper (2014)
Author(s)

Daniele Romano (TU Delft - Electrical Engineering, Mathematics and Computer Science)

Steven Raemaekers (TU Delft - Electrical Engineering, Mathematics and Computer Science, Software Improvement Group)

Martin Pinzger (TU Delft - Electrical Engineering, Mathematics and Computer Science, University of Klagenfurt)

Department
Software Technology
DOI related publication
https://doi.org/10.1109/ICSME.2014.57 Final published version
More Info
expand_more
Publication Year
2014
Language
English
Department
Software Technology
Article number
6976101
Pages (from-to)
351-360
ISBN (electronic)
9780769553030
Event
30th International Conference on Software Maintenance and Evolution, ICSME 2014 (2014-09-28 - 2014-10-03), Victoria, Canada
Downloads counter
175

Abstract

Recent studies have shown that the violation of the Interface Segregation Principle (ISP) is critical for maintaining and evolving software systems. Fat interfaces (i.e., interfaces violating the ISP) change more frequently and degrade the quality of the components coupled to them. According to the ISP the interfaces' design should force no client to depend on methods it does not invoke. Fat interfaces should be split into smaller interfaces exposing only the methods invoked by groups of clients. However, applying the ISP is a challenging task when fat interfaces are invoked differently by many clients. In this paper, we formulate the problem of applying the ISP as a multi-objective clustering problem and we propose a genetic algorithm to solve it. We evaluate the capability of the proposed genetic algorithm with 42,318 public Java APIs whose clients' usage has been mined from the Maven repository. The results of this study show that the genetic algorithm outperforms other search based approaches (i.e., random and simulated annealing approaches) in splitting the APIs according to the ISP.