El patrón de diseño Decorator es uno de los patrones estructurales más utilizados en la programación orientada a objetos.
Este patrón permite agregar funcionalidades adicionales a un objeto de forma dinámica, sin necesidad de crear subclases para cada combinación de funcionalidades.
En Kotlin, el patrón Decorator se implementa mediante la creación de una interfaz que define la funcionalidad base del objeto a decorar, y una clase base que implementa esta interfaz y que servirá como punto de partida para crear las decoraciones.
Las decoraciones son clases que implementan la misma interfaz que el objeto base, y que contienen una referencia a un objeto de la clase base.
Por ejemplo, imagina que queremos crear una aplicación que permita a los usuarios comprar pizzas con diferentes ingredientes.
Para ello, podemos crear una interfaz Pizza
que define la funcionalidad básica de una pizza, como su tamaño y su precio, y una clase base PizzaBase
que implementa esta interfaz y que representa una pizza básica sin ingredientes adicionales.
interface Pizza { val size: Int val price: Double } class PizzaBase(override val size: Int) : Pizza { override val price: Double get() = 10.0 * size }
Luego, podemos crear las diferentes decoraciones para agregar ingredientes a la pizza. Por ejemplo, una clase PepperoniPizzaDecorator
que agrega pepperoni a la pizza y aumenta su precio en 2 dólares.
class PepperoniPizzaDecorator(private val pizza: Pizza) : Pizza { override val size: Int get() = pizza.size override val price: Double get() = pizza.price + 2 }
De esta forma, podemos crear una pizza de tamaño mediano con pepperoni de la siguiente manera:
val pizza = PepperoniPizzaDecorator(PizzaBase(size = 2)) println(pizza.price) // imprime 14.0
Además, podemos crear combinaciones de ingredientes creando decoraciones que a su vez contengan otras decoraciones.
Por ejemplo, una clase ExtraCheesePizzaDecorator
que agrega queso extra a la pizza y aumenta su precio en 1 dólar.
class ExtraCheesePizzaDecorator(private val pizza: Pizza) : Pizza { override val size: Int get() = pizza.size override val price: Double get() = pizza.price + 1 }
De esta forma, podemos crear una pizza de tamaño grande con pepperoni y extra queso de la siguiente manera:
val pizza = ExtraCheesePizzaDecorator(PepperoniPizzaDecorator(PizzaBase(size = 3))) println(pizza.price) // imprime 17.0
Como se puede ver, el patrón Decorator nos permite agregar funcionalidades adicionales a un objeto de forma dinámica y sin necesidad de crear subclases para cada combinación posible.
Esto nos permite mantener un código limpio y fácil de extender en el futuro.
En resumen, el patrón Decorator es una herramienta muy útil en la programación orientada a objetos, y en Kotlin podemos implementarlo de forma sencilla utilizando interfaces y clases.
0 comentarios