Software architectural patterns in practice: an empirical study

Mohamad Kassab, Manuel Mazzara, Joo Young Lee, Giancarlo Succi

Research output: Contribution to journalArticlepeer-review

Abstract

Software architecture involves a series of decisions based on many factors in a wide range of software development. Architects face recurring issues in different software architecture design, and to reduce huge cost and risks, software architecture decisions can rely on a set of idiomatic patterns commonly named architectural styles or patterns. Architectural pattern determines the vocabulary of components and connectors that are used in instances of the pattern together with a set of constraints to combine the two. Little contemporary data exists to document actual practices used by software professionals when selecting and incorporating architectural patterns for their projects in industry. Therefore, a comprehensive survey of software professionals was conducted to attempt to discover these practices. This exploratory survey and its quantitative results offer opportunities for further interpretation and comparison. Data from this survey are presented in this paper and include characteristics of projects, practices, organizations, and practitioners related to the usage of architectural patterns. Some of the notable findings include that architectural patterns are widely used in software projects with the Model–View–Controller being the most common. Despite reported difficulties in incorporating architectural patterns, the majority of the software professionals revealed that patterns were the most essential for completing the projects. The most difficult pattern to implement and the most expensive to adopt was the peer-to-peer, while the easiest was the client–server.

Original languageEnglish (US)
Pages (from-to)263-271
Number of pages9
JournalInnovations in Systems and Software Engineering
Volume14
Issue number4
DOIs
StatePublished - Dec 3 2018

Keywords

  • Architectural patterns
  • Architectural tactics
  • Common practices
  • Quality attributes
  • Software architecture
  • Software professionals

ASJC Scopus subject areas

  • Software

Fingerprint

Dive into the research topics of 'Software architectural patterns in practice: an empirical study'. Together they form a unique fingerprint.

Cite this