Book Image

Software Architect's Handbook

By : Joseph Ingeno
Book Image

Software Architect's Handbook

By: Joseph Ingeno

Overview of this book

The Software Architect’s Handbook is a comprehensive guide to help developers, architects, and senior programmers advance their career in the software architecture domain. This book takes you through all the important concepts, right from design principles to different considerations at various stages of your career in software architecture. The book begins by covering the fundamentals, benefits, and purpose of software architecture. You will discover how software architecture relates to an organization, followed by identifying its significant quality attributes. Once you have covered the basics, you will explore design patterns, best practices, and paradigms for efficient software development. The book discusses which factors you need to consider for performance and security enhancements. You will learn to write documentation for your architectures and make appropriate decisions when considering DevOps. In addition to this, you will explore how to design legacy applications before understanding how to create software architectures that evolve as the market, business requirements, frameworks, tools, and best practices change over time. By the end of this book, you will not only have studied software architecture concepts but also built the soft skills necessary to grow in this field.
Table of Contents (19 chapters)

To get the most out of this book

Although readers should have experience of software development, no specific prerequisites are required to begin reading this book. All of the information that you need is contained in the various chapters. The book does not require knowledge of any particular programming language, framework, or tool. The code snippets in the book that illustrate various concepts are written in C#, but they are simple enough that prior C# experience is not necessary.

Download the color images

Conventions used

There are a number of text conventions used throughout this book.

CodeInText: Indicates code words in text, database table names, folder names, filenames, file extensions, pathnames, dummy URLs, user input, and Twitter handles. Here is an example: "Now we can use that constant in our GetFilePath method."

A block of code is set as follows:

public string GetFilePath()
{
string result = _cache.Get(FilePathCacheKey);

if (string.IsNullOrEmpty(result))
{
_cache.Put(FilePathCacheKey, DetermineFilePath());
result = _cache.Get(FilePathCacheKey);
}

return result;
}

When we wish to draw your attention to a particular part of a code block, the relevant lines or items are set in bold:

public string GetFilePath()
{
string result = _cache.Get(FilePathCacheKey);

if (string.IsNullOrEmpty(result))
{
_cache.Put(FilePathCacheKey, DetermineFilePath());
result = _cache.Get(FilePathCacheKey);
}

return result;
}

Bold: Indicates a new term, an important word, or words that you see onscreen. For example, words in menus or dialog boxes appear in the text like this. Here is an example: "In a direct dependency graph, at compile-time, Class A references Class B, which references Class C"

Warnings or important notes appear like this.
Tips and tricks appear like this.