On the automation of dependency-breaking refactorings in Java : a thesis presented in partial fulfilment of the requirements for the degree of Doctor of Philosophy in Computer Science at Massey University, Palmerston North, New Zealand
dc.contributor.author | Shah, Syed Muhammad Ali | |
dc.date.accessioned | 2014-03-25T23:10:19Z | |
dc.date.available | 2014-03-25T23:10:19Z | |
dc.date.issued | 2013 | |
dc.description.abstract | Over a period of time software systems grow large and become complex due to unsystematic changes that create a high level of interconnection among software artefacts. Consequently, maintenance becomes expensive and even making small changes may require considerable resources due to change propagation in the system, a phenomenon known as ripple e ects. Industrial evidence suggests that more resources are spent on the maintenance phase than on the initial development. It is evident that companies make huge investments to maintain legacy systems until a point comes where a complete restructuring of the system is required. In most cases, it becomes very expensive to refurbish legacy systems manually due to their inherent complexity. Several semi-automated solutions have been proposed to restructure simplified models of existing systems. It is still expensive, in terms of resources, to translate those model level transformations into source code transformations or refactorings. The question that arises here is whether we can automate the application of model level changes on the source code of programs. In this thesis, we have developed novel algorithms to automate the application of a class of architectural transformations related to improving modularity of existing programs. In order to evaluate our approach, we have analysed a large dataset of open source programs to determine whether the manipulation of models can be translated into source code refactorings, whether we can define constraints on those refactorings to preserve program correctness, and to which extent the automation of the whole process is possible. The results indicate that this automation process can be achieved to a significant level, which implies that certain economic benefits can be gained from the process. | en |
dc.identifier.uri | http://hdl.handle.net/10179/5176 | |
dc.language.iso | en | en |
dc.publisher | Massey University | en_US |
dc.rights | The Author | en_US |
dc.subject | Software refactoring | en |
dc.subject | Java (computer program language) | en |
dc.title | On the automation of dependency-breaking refactorings in Java : a thesis presented in partial fulfilment of the requirements for the degree of Doctor of Philosophy in Computer Science at Massey University, Palmerston North, New Zealand | en |
dc.type | Thesis | en |
massey.contributor.author | Shah, Syed Muhammad Ali | en |
thesis.degree.discipline | Computer Science | en |
thesis.degree.grantor | Massey University | en |
thesis.degree.level | Doctoral | en |
thesis.degree.name | Doctor of Philosophy (Ph.D.) | en |
Files
License bundle
1 - 1 of 1
Loading...
- Name:
- license.txt
- Size:
- 804 B
- Format:
- Item-specific license agreed upon to submission
- Description: