Skip to main content
Log in

An exploratory study of the effect of aspect-oriented programming on maintainability

  • Published:
Software Quality Journal Aims and scope Submit manuscript

Abstract

In this paper we describe an exploratory assessment of the effect of aspect-oriented programming on software maintainability. An experiment was conducted in which 11 software professionals were asked to carry out maintenance tasks on one of two programs. The first program was written in Java and the second in AspectJ. Both programs implement a shopping system according to the same set of requirements. A number of statistical hypotheses were tested. The results did seem to suggest a slight advantage for the subjects using the object-oriented system since in general it took the subjects less time to answer the questions on this system. Also, both systems appeared to be equally difficult to modify. However, the results did not show a statistically significant influence of aspect-oriented programming at the 5% level. We are aware that the results of this single small study cannot be generalized. We conclude that more empirical research is necessary in this area to identify the benefits of aspect-oriented programming and we hope that this paper will encourage such research.

This is a preview of subscription content, log in via an institution to check access.

Access this article

Price excludes VAT (USA)
Tax calculation will be finalised during checkout.

Instant access to the full article PDF.

Fig. 1
Fig. 2
Fig. 3
Fig. 4
Fig. 5
Fig. 6
Fig. 7
Fig. 8
Fig. 9

Similar content being viewed by others

Notes

  1. AspectJ, http://www.eclipse.org/aspectj

  2. Java, http://java.sun.com

  3. Both systems are available under: http://www.personal.rdg.ac.uk/∼sir04mb2/ShopSystem.zip

  4. Eclipse, 2006, http://www.eclipse.org

  5. MiniTab Statistical Software, Release 14.1, http://www.minitab.com/products/minitab/14

  6. AspectJ Development Tools (AJDT), 2006, http://www.eclipse.org/ajdt

References

  • Black, A., Hutchinson, N., Jul, E., & Levy, H. (1986). Object structure in the Emerald system. ACM SIGPLAN Notices, 21(11), 78–86.

    Article  Google Scholar 

  • Boehm, B. W., Brown, J. R., & Kaspar, J. R. et al. (1978). Characteristics of software quality, TRW series of software technology. North Holland: Amsterdam.

    Google Scholar 

  • Ceccato, M., & Tonella, P. (2004). Measuring the effects of software aspectization, CD-Rom. In Proceedings of the 1st Workshop on Aspect Reverse Engineering (WARE 2004), Delft, The Netherlands.

  • Chidamber, R., & Kemerer, C.F. (1994). A metrics suite for object-oriented design. IEEE TSE, 20(6), 476–493.

    Google Scholar 

  • Christensen, L. B. (1988). Experimental methodology (4th ed.). Newton, MA: Allyn and Bacon.

    Google Scholar 

  • Conover, W. J. (1971). Practical nonparametric statistics. John Wiley & Sons.

  • Dijkstra, E. W. (1982). On the role of scientific thought. In selected writings on computing: A personal perspective (pp. 60–66). Springer-Verlag.

  • Fenton, N. E., & Pfleeger, S. L. (1996). Software metrics: A rigorous and practical approach (2nd ed.). International Thomson Computer Press.

  • Filho, F. C., Rubira, C. M. F., & Garcia, A (2005). A quantitative study on the aspectization of exception handling. In ECOOP’2005 Workshop on Exception Handling in Object-Oriented Systems. Glasgow, UK.

  • Filho, F. C., Cacho, N., Maranhao, R., Figueiredo, E., Garcia, A., & Rubira, C. M. F. (2006). Exceptions and aspects: The devil is in the details. In Proceedings of the 14th ACM SIGSOFT International Symposium on Foundations of Software Engineering, Portland, Oregon, USA.

  • Freund, E. J., & Simon, G. A. (1997). Modern elementary statistics (9th ed.). New Jersey: Prentice Hall.

    Google Scholar 

  • Garcia, A., Sant’Anna, C., Figueiredo, E., Kulesza, U., Lucena, C., & von Staa, A. (2005). Modularizing design patterns with aspects: A quantitative study. In 4th International Conference on Aspect-Oriented Software Development (AOSD’05), Chicago, USA.

  • Hannemann, J., & Kiczales, G. (2002). Design pattern Implementations in Java and AspectJ. In ACM conference on object-oriented programming systems, languages, and applications.

  • Harris, R. J. (1975). A primer of multivariate statistics. Academic Press.

  • Harrison, R., Counsell, S. J., & Nithi, R. (2000). Experimental assessment of the effect of inheritance on the maintainability of object-oriented systems. Journal of Systems and Software, 52(2–3), 173–179.

    Article  Google Scholar 

  • Kersten, M., & Murphy, G. C. (1999). Atlas: A case study in building a web-based learning environment using aspect-oriented programming. In Proceedings of the 14th ACM SIGPLAN Conference on Object-Oriented Programming Systems, Languages and Applications (OOPSLA’99), Denver, Colorado.

  • Kiczales, G., Lamping, J., Mendhekar, A., Maeda, C., Videira Lopes, C., Loingtier, J.-M., & Irwin, J. (1997). Aspect-oriented programming. In Proceedings of ECOOP.

  • Kienzle, J., & Guerraoui, R. (2002). AOP: Does it make sense? The case of concurrency and failures. In Proceedings of the 16th European Conference on Object-Oriented Programming (ECOOP ’02), pp. 37–61.

  • Likert, R. (1932). A technique for the measurement of attitude. Archives of Psychology, 22(140), 55.

    Google Scholar 

  • Lopes, C. (1997). D: A language framework for distributed programming. PhD Thesis, College of Computer Science, Northeastern University.

  • Perry, D. E., Porter, A. A., & Votta, L. G. (2000). Empirical studies of software engineering: A roadmap. ICSE—Future of SE Track 2000, 345–355.

  • Pfahl, D., Laitenberger, O., Dorsch, J., & Ruhe, G. (2003). An externally replicated experiment for evaluating the learning effectiveness of using simulations in software project management education. Empirical Software Engineering, 8(4), 367–395.

    Article  Google Scholar 

  • Prechelt, L., Unger, B., & Schmidt, D. (1997). Replication of the first controlled experiment on the usefulness of design patterns: Detailed desciption and evaluation, Technical Report wucs-97–34, Department of Computer Science, Washington University, St. Louis, MO, pp. 63130–64899.

  • Rashid, A., & Chitchyan, R. (2003). Persistence as an aspect. In Proceedings of the 2nd International Concference on Aspect-Oriented Software Development (AOSD '03), Boston, Massachusetts.

  • Roychoudhury, S., Gray, J., Wu, H., Zhang, J., & Lin, Y. (2003). A comparative analysis of metaprogramming and aspect-orientation. In 41st Annual ACM South East Conference, Savannah, GA.

  • Sant’Anna, C., Garcia, A., Chavez, Ch., Lucena, C., & von Staa, A. (2003). On the reuse and maintenance of aspect-oriented software: An assessment framework. In Proceedings of the Brazilian Symposium on Software Engineering (SBES’03), Manaus, Brazil, pp. 19–34.

  • Soares, S., Laureano, E., & Borba, P. (2002). Implementing distribution and persistence aspects with AspectJ. In Proceedings of the 17th ACM SIGPLAN Conference on Object-Oriented Programming Systems, Languages and Applications (OOPSLA’02), Seattle, Washington.

  • Stephens, M. A. (1974). EDF statistics for goodness of fit and some comparisons. Journal of the American Statistical Association, 69, 730–737.

    Article  Google Scholar 

  • Tsang, S. L., Clarke, S., & Baniassad, E. L. A. (2004). An evaluation of aspect-oriented programming for Java-based real-time systems development. In Proceedings of IEEE International Symposium on Object-oriented Real-time distributed Computing (ISORC), Vienna, Austria.

  • Walker, R. J., Baniassad, E. L. A., & Murphy, G. C. (1999). An initial assessment of aspect-oriented programming. In Proceedings of the 21st International Conference on Software Engineering (ICSE ’99), pp. 120–130.

  • Zhao, J. (2004). Measuring coupling in aspect-oriented systems. In 10th International Software Metrics Symposium (METRICS ’2004), (Late Breaking Paper), Chicago, USA.

Download references

Acknowledgements

We would like to thank all participants of the pre-pilot study, the pilot study and the experiment for the time and effort they invested as well as all anonymous reviewers for their helpful comments.

Author information

Authors and Affiliations

Authors

Corresponding author

Correspondence to Marc Bartsch.

Appendix A: Questions

Appendix A: Questions

  1. Q1.

    Please list all classes and aspects, if any exist, that are defined in the source code.

  2. Q2.

    What is the output from this program? Please write down every line that will be printed.

  3. Q3.

    Describe how you would change the program so that an exception will be thrown if a user attempts to use the shop after he has been idle for more than 5 min. Please state clearly every change you would make to the code i.e., every line change, addition or removal of code. The choice of programming language is not important. For a correct solution you can either use Java or AspectJ.

  4. Q4.

    How understandable, on a scale of 1–5, do you think this program is?

   

Rights and permissions

Reprints and permissions

About this article

Cite this article

Bartsch, M., Harrison, R. An exploratory study of the effect of aspect-oriented programming on maintainability. Software Qual J 16, 23–44 (2008). https://doi.org/10.1007/s11219-007-9022-7

Download citation

  • Published:

  • Issue Date:

  • DOI: https://doi.org/10.1007/s11219-007-9022-7

Keywords

Navigation