Using Z to specify object-oriented software complexity measures

Software metrics have been a key strategy for software engineers to assure software quality and measure software complexity for many years. However, the complexity metrics of object inheritance hierarchies have not yet been carefully studied. This paper proposes an inheritance level-based metric for measuring the object-oriented software complexity of an inheritance hierarchy. We introduce an algorithm which is proved to be complete and sound to decompose an inheritance hierarchy into a number of measured elements, namely, unit repeated inheritances (URIs). We use the Z specification to model the inheritance hierarchy and describe an inheritance level technique (ILT) based on URIs as a guide to measure the inheritance hierarchy. The proposed metric shows that inheritance has a close relation to object-oriented software complexity. The metric also reveals that overuse of repeated (multiple) inheritance will increase software complexity and thus is prone to implicit software errors. The measurement of inheritance metrics is formed based on the proposed mechanism.

[1]  Warren A. Harrison,et al.  A complexity measure based on nesting level , 1981, SIGP.

[2]  Chris F. Kemerer,et al.  Towards a metrics suite for object oriented design , 2017, OOPSLA '91.

[3]  Shinji Kusumoto,et al.  Analysis of metrics for object-oriented program complexity , 1994, Proceedings Eighteenth Annual International Computer Software and Applications Conference (COMPSAC 94).

[4]  Sallie M. Henry,et al.  Object-oriented metrics that predict maintainability , 1993, J. Syst. Softw..

[5]  J. Michael Spivey,et al.  The Z notation - a reference manual , 1992, Prentice Hall International Series in Computer Science.

[6]  Chris F. Kemerer,et al.  A Metrics Suite for Object Oriented Design , 2015, IEEE Trans. Software Eng..

[7]  Chi-Ming Chung,et al.  Inheritance-Based Metric for Complexity Analysis in Object-Oriented Design , 1992, J. Inf. Sci. Eng..

[8]  H. E. Dunsmore,et al.  Data Referencing: An Empirical Investigation , 1979, Computer.