Software Design Patterns and Principles - Part 7 (Composite Design Pattern)
Saiful Islam Rasel
Senior Engineer, SDE @ bKash | Ex: AsthaIT | Sports Programmer | Problem Solver | FinTech | Microservice | Java | Spring-boot | C# | .NET | PostgreSQL | DynamoDB | JavaScript | TypeScript | React.js | Next.js | Angular
**** Previous Parts ****
Part 1: Introduction
Story:
One of my close bro Siam, wants to create a quiz competition app. The feature of this app will be fantastic. Siam bro wants, in a running quiz competition both a single individual player and multiple player as a team can participate. So score will be calculated based on player individual point and also his team members points (if have any) and leadership board will be updated based on that. Now Siam bro is in tension how he will design and develop his code to tackle this complex, composite, hierarchical and tree (team players connection) like structures?
Composite Design Pattern:
Definition:
Composite is a structural design pattern that lets you compose objects into tree structures and then work with these structures as if they were individual?objects.
As the definition stat, Composite pattern helps us to compose and interact with complex, hierarchical or tree structures system. It gives a opportunity of working with a complex and composite object as a individual object. The user or caller needn't concern about the structure, they just use the common interface that's it.
Problem:
In the above story, Siam bro face a problem of maintaining composition and hierarchical structures of players. Another challenging part is combining the team players and treat them as an individual player (as single and team both can participate). Also other challenge is calculating the score. So how can Siam bro design for solving these problems?
Certainly! The composite design pattern is applicable in various scenarios where you have hierarchical/tree structures and need to treat individual objects and compositions of objects uniformly. Below are some scenarios where the composite pattern can be applied:
In all these scenarios, the composite pattern provides a way to work with hierarchical structures in a consistent and flexible manner, enabling you to treat individual elements and compositions of elements uniformly.
领英推荐
Solution:
From the above definition of composite pattern, it gives us a power of composite multiple object and gives a common interface to working with them as if it is an individual object. So in the above stated problem of Siam bro can be solved using the composite pattern. Siam bro can declare a common interface which gives a method of calculating points and both composite object (team, collection of players) and single object (individual player) will implement. That way client can be just call the point calculation method and the overall problem solved.
We can also use or implement composite pattern as a solution of the problems stated earlier sections as well.
UML Diagram:
Here in UML diagram we can see that, Client interacts with Component interface. And Leaf (which is a standalone object) and Composite (which is a complex/combination of Leaf objects) implements the Component interface. So Client need not know about the objects type (Leaf or Composite). Client can interact like e individual object.
Type safety primarily concerns ensuring that the types of components being combined are compatible and safe at compile time, preventing type-related errors. Uniformity focuses on providing a consistent interface for interacting with components and composites, promoting simplicity, modularity, and ease of use for clients.
When to use:
Implementation:
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public interface Score {
double calculatePoint();
}
public class Player implements Score {
private final double point;
public Player(double point) {
this.point= point;
}
@Override
public double calculatePoint() {
return point;
}
}
public class Team implements Score {
private final List<Player> players = new ArrayList<>();
public Team(Player... players) {
children.addAll(Arrays.asList(players));
}
@Override
public double calculatePoint() {
return players.stream().mapToDouble(Player::calculatePoint).sum();
}
}
public class QuizApp {
public static void main(String[] args) {
Score player1 = new Player(20);
Score player2 = new Player(10);
Score player3 = new Player(30);
Score team1 = new Team(player2, player3);
System.out.println(player1.calculatePoint());
System.out.println(team1.calculatePoint());
}
}
Another C# implementation of composite design pattern.
Achieved Design Principles:
The Composite pattern achieves several design principles, contributing to the overall effectiveness and maintainability of software systems:
Overall, by adhering to these design principles, the Composite pattern promotes a modular, flexible, and maintainable design, making it well-suited for scenarios involving hierarchical structures and the manipulation of individual elements and compositions of elements.
Happy Learning !!!
Happy Coding !!!
Happy Programming !!!
Senior Engineer, SDE @ bKash | Ex: AsthaIT | Sports Programmer | Problem Solver | FinTech | Microservice | Java | Spring-boot | C# | .NET | PostgreSQL | DynamoDB | JavaScript | TypeScript | React.js | Next.js | Angular
9 个月Previous Parts: Part 1:?https://www.dhirubhai.net/pulse/software-design-patterns-principles-part-1-saiful-islam-rasel-eqfec/ Part 2:?https://www.dhirubhai.net/pulse/software-design-patterns-principles-part-2-list-most-rasel-kepmc/ Part 3:?https://www.dhirubhai.net/pulse/software-design-patterns-principles-part-3-factory-method-rasel-ir4tc/ Part 4:?https://www.dhirubhai.net/pulse/software-design-patterns-principles-part-4-builder-pattern-rasel-41cmc/ Part 5:?https://www.dhirubhai.net/pulse/software-design-patterns-principles-part-5-adapter-pattern-rasel-nfjrc/ Part 6: https://www.dhirubhai.net/pulse/software-design-patterns-principles-part-6-decorator-rasel-ijxwc/