Micro patterns in Java code

J Gil, I Maman - Proceedings of the 20th annual ACM SIGPLAN …, 2005 - dl.acm.org
J Gil, I Maman
Proceedings of the 20th annual ACM SIGPLAN conference on object-oriented …, 2005dl.acm.org
Micro patterns are similar to design patterns, except that micro patterns are stand at a lower,
closer to the implementation, level of abstraction. Micro patterns are also unique in that they
are mechanically recognizable, since each such pattern can be expressed as a formal
condition on the structure of a class. This paper presents a catalog of 27 micro-patterns
defined on Java classes and interfaces. The catalog captures a wide spectrum of common
programming practices, including a particular and (intentionally restricted) use of …
Micro patterns are similar to design patterns, except that micro patterns are stand at a lower, closer to the implementation, level of abstraction. Micro patterns are also unique in that they are mechanically recognizable, since each such pattern can be expressed as a formal condition on the structure of a class.This paper presents a catalog of 27 micro-patterns defined on Java classes and interfaces. The catalog captures a wide spectrum of common programming practices, including a particular and (intentionally restricted) use of inheritance, immutability, data management and wrapping, restricted creation, and emulation of procedural-, modular-, and even functional- programming paradigms with object oriented constructs. Together, the patterns present a set of prototypes after which a large portion of all Java classes and interfaces are modeled. We provide empirical indication that this portion is as high as 75%.A statistical analysis of occurrences of micro patterns in a large software corpus, spanning some 70,000 Java classes drawn from a rich set of application domains, shows, with high confidence level that the use of these patterns is not random. These results indicate consciousness and discernible design decisions, which are sustained in the software evolution. With high confidence level, we can also show that the use of these patterns is tied to the specification, or the purpose, that the software realizes.The traceability, abundance and the statistical significance of micro pattern occurrence raise the hope of using the classification of software into these patterns for a more founded appreciation of its design and code quality.
ACM Digital Library