diff --git a/architecture.html b/architecture.html index 594738a..a516436 100644 --- a/architecture.html +++ b/architecture.html @@ -51,7 +51,7 @@

The most common approach to dealing with both architectural mismatch and the changing of requirements over time is refactoring, which means changing the architecture of an implementation without changing its behavior. Refactoring is something most developers do as part of changing a system (Murphy-Hill et al 2009, Silva et al. 2016). Refactoring code to eliminate mismatch and technical debt can simplify change in the future, saving time (Ng et al. 2006) and prevent future defects (Kim et al. 2012). -

Research on the actual activity of software architecture is actually somewhat sparse. One of the more recent syntheses of this work is Petre et al.'s book, Software Design Decoded (Petre et al. 2016), which distills many of the practices and skills of software design into a set of succinct ideas. For example, the book states, "Every design problem has multiple, if not infinite, ways of solving it. Experts strongly prefer simpler solutions over complex ones, for they know that such solutions are easier to understand and change in the future." These ideas, while powerful in their conciseness, are also grounded in substantial research on how software architects think and work.

+

Research on the actual activity of software architecture is actually somewhat sparse. One of the more recent syntheses of this work is Petre et al.'s book, Software Design Decoded (Petre et al. 2016), which distills many of the practices and skills of software design into a set of succinct ideas. For example, the book states, "Every design problem has multiple, if not infinite, ways of solving it. Experts strongly prefer simpler solutions over complex ones, for they know that such solutions are easier to understand and change in the future." And yet, in practice, studies of how projects use APIs often show that developers do the exact opposite, building projects with dependencies on large numbers of sometimes trivial APIs. Some behavior suggests that while software architects like simplicity of implementation, software developers are often choosing whatever is easiest to build, rather than whatever is least risky to maintain over time (Abdalkareem 2017).

Next chapter: Specifications
@@ -59,6 +59,8 @@ +

Rabe Abdalkareem, Olivier Nourry, Sultan Wehaibi, Suhaib Mujahid, and Emad Shihab. 2017. Why do developers use trivial packages? An empirical case study on npm. In Proceedings of the 2017 11th Joint Meeting on Foundations of Software Engineering (ESEC/FSE 2017). ACM, New York, NY, USA, 385-395.

+

Len Bass, Bonnie E. John. 2003. Linking usability to software architecture patterns through general scenarios. Journal of Systems and Software, Volume 66, Issue 3, Pages 187-197.

Kent Beck, Ron Crocker, Gerard Meszaros, John Vlissides, James O. Coplien, Lutz Dominick, and Frances Paulisch. 1996. Industrial experience with design patterns. In Proceedings of the 18th international conference on Software engineering (ICSE '96). IEEE Computer Society, Washington, DC, USA, 103-114.

Jürgen Cito, Philipp Leitner, Thomas Fritz, and Harald C. Gall. 2015. The making of cloud applications: an empirical study on software development for the cloud. In Proceedings of the 2015 10th Joint Meeting on Foundations of Software Engineering (ESEC/FSE 2015). ACM, New York, NY, USA, 393-403.