Book Image

Design Patterns and Best Practices in Java

By : Kamalmeet Singh, Adrian Ianculescu, Lucian-Paul Torje
Book Image

Design Patterns and Best Practices in Java

By: Kamalmeet Singh, Adrian Ianculescu, Lucian-Paul Torje

Overview of this book

Having a knowledge of design patterns enables you, as a developer, to improve your code base, promote code reuse, and make the architecture more robust. As languages evolve, new features take time to fully understand before they are adopted en masse. The mission of this book is to ease the adoption of the latest trends and provide good practices for programmers. We focus on showing you the practical aspects of smarter coding in Java. We'll start off by going over object-oriented (OOP) and functional programming (FP) paradigms, moving on to describe the most frequently used design patterns in their classical format and explain how Java’s functional programming features are changing them. You will learn to enhance implementations by mixing OOP and FP, and finally get to know about the reactive programming model, where FP and OOP are used in conjunction with a view to writing better code. Gradually, the book will show you the latest trends in architecture, moving from MVC to microservices and serverless architecture. We will finish off by highlighting the new Java features and best practices. By the end of the book, you will be able to efficiently address common problems faced while developing applications and be comfortable working on scalable and maintainable projects of any size.
Table of Contents (15 chapters)
Title Page
Packt Upsell
Contributors
Preface
Index

Composite pattern


The composite pattern, as the name suggests, is used when composing objects into a complex structure that acts as one (refer to the following diagram). Internally, it is using data structures, such as trees, graphs, arrays, or linked lists to represent the model:

The JVM offers the best example of a composite pattern, since it is usually implemented as a stack machine (for portability reasons). Operations are pushed and popped from the current thread stack. For example, to calculate what 1 + 4 - 2 equals, it pushes 1, pushes 4, and executes add. The stack now has only value 5, pushes 2, and executes minus. Now the stack has only value 3, which is popped. The operation 1 + 4 + 2 - (reversed polish notation) can be easily modeled using the composite pattern, where each node is either a value, complex value, or an operand. Each node has a perform method that performs the operation (push, execute, and pop or combine, depending on the type).

Composite makes use of recursive composition...