Decorator Design Pattern

Decorator Design Pattern

18 Jun 2024
Intermediate
130K Views
3 min read
Learn via Video Course & by Doing Hands-on Labs

⭐ .NET Design Patterns Course: Design Patterns in C# Online Training

Decorator design pattern falls under Structural Pattern of Gang of Four (GOF) Design Patterns in .Net. Decorator pattern is used to add new functionality to an existing object without changing its structure. Hence Decorator pattern provides an alternative way to inheritance for modifying the behavior of an object. In this article, I would like to share what is decorator pattern and how is it work?

What is Decorator Pattern

The decorator pattern is used to add new functionality to an existing object without changing its structure.

This pattern creates a decorator class which wraps the original class and add new behaviors/operations to an object at run-time.

Decorator Pattern - UML Diagram & Implementation

The UML class diagram for the implementation of the decorator design pattern is given below:

The classes, interfaces, and objects in the above UML class diagram are as follows:

  1. Component

    This is an interface containing members that will be implemented by ConcreteClass and Decorator.

  2. ConcreteComponent

    This is a class which implements the Component interface.

  3. Decorator

    This is an abstract class which implements the Component interface and contains the reference to a Component instance. This class also acts as base class for all decorators for components.

  4. ConcreteDecorator

    This is a class which inherits from Decorator class and provides a decorator for components.

C# - Implementation Code

public interface Component
{
 void Operation();
}

public class ConcreteComponent : Component
{
 public void Operation()
 {
 Console.WriteLine("Component Operation");
 }
}

public abstract class Decorator : Component
{
 private Component _component;

 public Decorator(Component component)
 {
 _component = component;
 }

 public virtual void Operation()
 {
 _component.Operation();
 }
}

public class ConcreteDecorator : Decorator
{
 public ConcreteDecorator(Component component) : base(component) { }

 public override void Operation()
 {
 base.Operation();
 Console.WriteLine("Override Decorator Operation");
 }
}

Decorator Pattern - Example

Who is what?

The classes, interfaces, and objects in the above class diagram can be identified as follows:

  1. Vehicle - Component Interface.

  2. HondaCity- ConcreteComponent class.

  3. VehicleDecorator- Decorator Class.

  4. Special Offer- ConcreteDecorator class.

C# - Sample Code

/// <summary>
/// The 'Component' interface
/// </summary>
public interface Vehicle
{
 string Make { get; }
 string Model { get; }
 double Price { get; }
}

/// <summary>
/// The 'ConcreteComponent' class
/// </summary>
public class HondaCity : Vehicle
{
 public string Make
 {
 get { return "HondaCity"; }
 }

 public string Model
 {
 get { return "CNG"; }
 }

 public double Price
 {
 get { return 1000000; }
 }
}

/// <summary>
/// The 'Decorator' abstract class
/// </summary>
public abstract class VehicleDecorator : Vehicle
{
 private Vehicle _vehicle;

 public VehicleDecorator(Vehicle vehicle)
 {
 _vehicle = vehicle;
 }

 public string Make
 {
 get { return _vehicle.Make; }
 }

 public string Model
 {
 get { return _vehicle.Model; }
 }

 public double Price
 {
 get { return _vehicle.Price; }
 }

}

/// <summary>
/// The 'ConcreteDecorator' class
/// </summary>
public class SpecialOffer : VehicleDecorator
{
 public SpecialOffer(Vehicle vehicle) : base(vehicle) { }

 public int DiscountPercentage { get; set; }
 public string Offer { get; set; }

 public double Price
 {
 get
 {
 double price = base.Price;
 int percentage = 100 - DiscountPercentage;
 return Math.Round((price * percentage) / 100, 2);
 }
 }

}

/// <summary>
/// Decorator Pattern Demo
/// </summary>
class Program
{
 static void Main(string[] args)
 {
 // Basic vehicle
 HondaCity car = new HondaCity();

 Console.WriteLine("Honda City base price are : {0}", car.Price);

 // Special offer
 SpecialOffer offer = new SpecialOffer(car);
 offer.DiscountPercentage = 25;
 offer.Offer = "25 % discount";

 Console.WriteLine("{1} @ Diwali Special Offer and price are : {0} ", offer.Price, offer.Offer);

 Console.ReadKey();

 }
}

decorator Pattern Demo - Output

When to use it?

  1. Add additional state or behavior to an object dynamically.

  2. Make changes to some objects in a class without affecting others.

Read More Articles Related to Design patterns
What do you think?

I hope you will enjoy the decorator Pattern while designing your software. I would like to have feedback from my blog readers. Your valuable feedback, question, or comments about this article are always welcome.

FAQs

Q1. What is the purpose of the Decorator Design Pattern?

The Decorator Design Pattern allows you to dynamically add additional functionality to an item without changing its structure. Wrapping objects in decorator classes enables flexible and reusable behavior additions.

Q2. What are two capabilities of the decorator pattern?

The Decorator Pattern has two capabilities: it may dynamically add new functionality to an object without changing its code, and it can apply many decorators, allowing for diverse combinations of behavior.

Q3. What problems does the decorator pattern solve?

The Decorator Pattern overcomes the challenge of dynamically extending functionality without altering existing code, as well as avoiding the complexity of subclassing for every potential feature combination. It also helps to manage new duties by layering them in a flexible and modular manner.

Q4. How does the Decorator Pattern differ from the Adapter Pattern?

The Decorator Pattern dynamically adds additional functionality to objects while preserving their interface, whereas the Adapter Pattern alters an object's interface to make it compatible with other systems. Essentially, decorators improve behavior and adapters provide compatibility.
Share Article

Live Classes Schedule

Our learn-by-building-project method enables you to build practical/coding experience that sticks. 95% of our learners say they have confidence and remember more when they learn by building real world projects.
ASP.NET Core Certification TrainingSep 15SAT, SUN
Filling Fast
09:30AM to 11:30AM (IST)
Get Details
Software Architecture and Design TrainingSep 22SAT, SUN
Filling Fast
07:00AM to 09:00AM (IST)
Get Details
ASP.NET Core Certification TrainingSep 29SAT, SUN
Filling Fast
08:30PM to 10:30PM (IST)
Get Details
ASP.NET Core ProjectOct 13SAT, SUN
Filling Fast
10:00AM to 12:00PM (IST)
Get Details

Can't find convenient schedule? Let us know

About Author
Shailendra Chauhan (Microsoft MVP, Founder & CEO at Scholarhat by DotNetTricks)

Shailendra Chauhan is the Founder and CEO at ScholarHat by DotNetTricks which is a brand when it comes to e-Learning. He provides training and consultation over an array of technologies like Cloud, .NET, Angular, React, Node, Microservices, Containers and Mobile Apps development. He has been awarded Microsoft MVP 8th time in a row (2016-2023). He has changed many lives with his writings and unique training programs. He has a number of most sought-after books to his name which has helped job aspirants in cracking tough interviews with ease.
Accept cookies & close this