Model-Driven Engineering Languages and Systems

Volume 8107 of the series Lecture Notes in Computer Science pp 604-621

Concern-Oriented Software Design

  • Omar AlamAffiliated withSchool of Computer Science, McGill University
  • , Jörg KienzleAffiliated withSchool of Computer Science, McGill University
  • , Gunter MussbacherAffiliated withUniversity of Ottawa


There exist many solutions to solve a given design problem, and it is difficult to capture the essence of a solution and make it reusable for future designs. Furthermore, many variations of a given solution may exist, and choosing the best alternative depends on application-specific high-level goals and non-functional requirements. This paper proposes Concern-Oriented Software Design, a modelling technique that focuses on concerns as units of reuse. A concern groups related models serving the same purpose, and provides three interfaces to facilitate reuse. The variation interface presents the design alternatives and their impact on non-functional requirements. The customization interface of the selected alternative details how to adapt the generic solution to a specific context. Finally, the usage interface specifies the provided behaviour. We illustrate our approach by presenting the concern models of variations of the Observer design pattern, which internally depends on the Association concern to link observers and subjects.