Restructuring Functions with Low Cohesion

Arun Lakhotia and Jean-Christophe Deprez

Abstract

We present a technique for restructuring functions with low cohesion into functions with high cohesion. Such restructuring is desirable when re-architecting a legacy system into an object-oriented architecture. The restructured system has functions with higher cohesion and hence lower coupling. This enables finer-grained grouping of functions into objects.

Automatically decomposing a function is difficult when its computations are interleaved. The challenge lies in programmatically identifying and separating the various activities performed by a complex code segment. The technique presented partitions the set of output variables of a function on the basis of their pairwise cohesion. Program slicing is then used to identify the statements that perform computations for each variable group in the partition. New functions corresponding to the slices are created to replace the original function.

Experiences with restructuring real-world code using a tool that implements the technique are presented.

KEYWORDS Software reengineering, restructuring, modularization, program tucking, cohesion

Full paper


Arun Lakhotia <arun@cacs.usl.edu>
Last modified: Tue Jul 27 10:12:21 1999