Skip to content

Latest commit

 

History

History
282 lines (229 loc) · 10.7 KB

README.md

File metadata and controls

282 lines (229 loc) · 10.7 KB

Object-Oriented Programming (OOP) Design Patterns examples with Java

Scope

The design patterns of this repository refer to those of the Gang of Four (GoF), who are the 4 authors (Erich Gamma, Richard Helm, Ralph Johnson, and John Vlissides) of the software engineering book Design Patterns: Elements of Reusable Object-Oriented Software first published in 1994.

There is at least 1 example coded in Java for every single of their 23 design patterns for Object-oriented programming.

Repository Organization

Patterns examples are separated by packages.

Classes are divided into packages named accordingly to the GoF's book terminology to facilitate the comprehension of the role each class plays in the corresponding pattern.

The runnable classes are in the root of each pattern package or inside client package.

There are classes with the prefix Any, such as AnyObject or AnyString. When these classes appear, it means they could be substituted by any other class.

Design Patterns

Creational patterns

Abstract factory / Kit

DEFINITION: Provide an interface for creating families of related or dependent objects without specifying their concrete classes.

Participants:

  • AbstractFactory: FurnitureFactory
  • ConcreteFactory: LivingRoomFurnitureFactory, OfficeFurnitureFactory
  • ConcreteFactorySingleton: LivingRoomFurnitureFactorySingleton, OfficeFurnitureFactorySingleton
  • ProductFamily1:
    • interface Table
      • LivingRoomTable
      • OfficeTable
  • ProductFamily2:
    • interface Chair
      • LivingRoomChair
      • OfficeChair

Builder

DEFINITION: Separate the construction of a complex object from its representation so that the same construction process can create different representations.

Participants:

  • Builder: interface OrderBuilder
  • ConcreteBuilder: BurgerMenuBurger
  • Director: Cashier (Builder)
  • Product: Order (Item)

Non-pattern participants:

  • Model:
    • abstract Item
      • abstract Burger
        • CheeseBurger
        • Veggie
      • abstract Drink
        • Water
        • Coke
      • abstract Companion
        • OnionRings
      • abstract Dessert
        • IceCream

Factory method / Virtual Constructor

DEFINITION: Define an interface for creating an object, but let subclasses decide which class to instantiate. Factory method lets a class defer instantiation to subclasses.

Variants: abstract creator and parameterized creator.

Abstract creator variant Participants:

  • Product: abstract Car
  • ConcreteProduct: SuvCar
  • Creator: abstract CarCreator::createCar()
  • ConcreteCreator: SuvCarCreator

Parameterized creator variant Participants:

  • Product: abstract Car
  • ConcreteProduct: SuvCar, TourismCar
  • Creator: CarCreator::createCar(CarType)

Prototype

DEFINITION: Specify the kinds of objects to create using a prototypical instance, and create new objects by coping this prototype.

Variants: Deep copy and Shadow copy clone techniques.

Participants:

  • Client:
    • Graphic::getRepresentation
    • GraphicTool (Graphic)
  • Prototype: interface MusicalNotePrototype extends Graphic
  • ConcretePrototype:
    • HalfNotePrototypeDeepCopy
    • HalfNotePrototypeShadowCopy

Non-pattern participants:

  • Model: Representation

Singleton

DEFINITION: Ensure a class only has one instance, and provide a global point of access to it.

Variants: Early instantiation and Lazy instantiation.

Participants:

  • Singleton: EarlySingleton (AnyObject), LazySingleton (AnyObject)

Non-pattern participants:

  • Model: AnyObject

Structural patterns

Adapter / Wrapper

DEFINITION: Convert the interface of a class into another interface clients expect. Adapter lets classes work together that couldn't otherwise because of incompatible interface.

Variants: Using abstract operations.

Participants of adapter using abstract operations variant:

  • Client: Shop
  • Adaptee: Product
  • Target Interface: Stock
  • Adapter: ProductStock

Bridge / Handle / Body

DEFINITION: Decouples an abstraction from its implementation so that the two can vary independently.

Participants:

  • Abstraction: DomoticsSystem
  • RefinedAbstraction: RectoryDomoticsSystem, SportsCenterDomoticsSystem
  • Implementor: Door
  • ConcreteImplementor: FrontDoor, InnerDoor

Non-pattern participants:

  • View: DataForm

Composite

DEFINITION: Compose objects into tree structures to represent part-whole hierarchies. Composite lets clients treat individual objects and compositions of objects uniformly.

Participants:

  • Component: Shape
  • Composite: Grouping
  • Leaf: Circle, Square
  • Client: Main

Decorator / Wrapper

DEFINITION: Attach additional responsibilities to an object dynamically. Decorators provide a flexible alternative to subclassing for extending functionality.

Participants:

  • Component: CleaningMachine
  • ConcreteComponent: BikeCleaningMachine, CarCleaningMachine
  • Decorator: Cleaning
  • ConcreteDecorator: HotWaterCleaning, HotWaterWithSoapCleaning

Facade

DEFINITION: Provides a unified interface to a set of interfaces in a subsystem. Facade defines a higher-level interface that makes the subsystem easier to use.

Participants:

  • Client: AnyVideoGame implements VideoGame
  • Facade: VideoGamesConsole
  • Subsystem:
    • VideoGamesConsoleImpl (VideoGame, DiskReader)
    • DiskReader
    • interface VideoGame

Flyweight

DEFINITION: Use sharing to support large numbers of fine-grained objects efficiently.

Participants:

  • Flyweight: Sprite
  • FlyweightFactory: SpriteFactory
  • ConcreteFlyweight: ObjectSprite
  • Context: Square
  • Client: Board

Limitations:

  • UnsharedConcreteFlyweight participant is not included. To include it, it would be necessary to implement Composite design pattern inside this example where UnsharedConcreteFlyweight participant would act as Composite, Flyweight as Component and ConcreteFlyweight as Leaf. Possible classes for UnsharedConcreteFlyweight would be RowSprite and ColumnSprite.

Proxy / Surrogate

DEFINITION: Provides a surrogate or placeholder for another object to control access to it.

Variants: Virtual proxy.

Participants of virtual proxy variant:

  • RealSubject: Webpage implements WebpageService
  • Proxy: WebpageProxy implements WebpageService
  • Subject: WebpageService(HtmlDocument)

Non-pattern participants:

  • Model: HtmlDocument

Behavioral patterns

Chain of responsibility

DEFINITION: Avoid coupling the sender of a request to its receiver by giving more than one object a chance to handle the request. Chain the receiving objects and pass the request along the chain until an object handles it.

Participants:

  • Handler: abstract HtmlElement (AnyRequest)
  • ConcreteHandler: DivHtmlElement, ButtonHtmlElement
  • Client: Main

Non-pattern participants:

  • Model: AnyRequest

Command / Action / Transaction

DEFINITION: Encapsulate a request as an object, thereby letting you parameterize clients with different requests, queue or log requests, and support undoable operations.

Participants:

  • Command: Command (Gui)
  • ConcreteCommand: CopyCommand extends Command
  • Invoker: Button (Command), Shortcut (Command)
  • Receiver: Gui (Command, Invoker)
  • Client: Main

Interpreter

DEFINITION: Given a language, define a representation for its grammar along with an interpreter that uses the representation to interpret sentences in the language.

Participants:

  • AbstractExpression: interface RegularExpression
  • TerminalExpression: LiteralExpression
  • NonTerminalExpression: AlternationExpression, RepetitionExpression, SequenceExpression
  • Context (AnyString)
  • Client: LiteralExpressionTest, AlternationExpressionTest, RepetitionExpressionTest, SequenceExpressionTest

Limitations:

  • Parser to create an Abstract Syntax Tree (AST) not included.
  • Visitor pattern is not used to implement interpret operations.
  • Terminal symbols are not shared by means of the Flyweight pattern.

Iterator / Cursor

DEFINITION: Provide a way to access the elements of an aggregate object sequentially without exposing its underlying representation.

Variants: External non-robust polymorphic iterator.

Participants of external non-robust polymorphic iterator variant:

  • Iterator: interface Iterator
  • ConcreteIterator: SingleLinkedListIterator
  • Aggregate: Aggregate
  • ConcreteAggregate: SingleLinkedList
  • Client: Main

Mediator

DEFINITION: Define an object that encapsulate how a set of objects interact. Mediator promotes loose couping by keeping objects from referring to each other explicitly, and it lets you vary their interaction independently.

Participants:

  • Mediator: interface mediator (Message)
  • ConcreteMediator: ChatRoom
  • ColleagueClass: interface Participant (Message)
  • ConcreteColleagueClass: ChatUser

Non-pattern participants:

  • Model: Message

Memento / Token

DEFINITION: Without violating encapsulation, capture and externalize an object's internal state so that the object can be restored to this state later.

Participants:

  • Originator: StateDesiredToStore
  • Memento: Memento
  • Caretaker: Main

Observer / Dependents / Publish-Subscribe

DEFINITION: Define a one-to-many dependency between objects so that when one object changes state, all its dependents are notified and updated automatically.

Variants: Have state-setting operation on Subject call Notify after they change the subject's state, neither push nor pull model.

Participants:

  • Subject: abstract Subject
  • ConcreteSubject: ConcreteSubject
  • Observer: interface Observer
  • ConcreteObserver: ConcreteObserver

Limitations:

  • Not specifying modifications of interest explicitly.
  • Not encapsulating complex update semantics into a ChangeManager participant.

State / Objects for States

DEFINITION: Allows an object to alter its behavior when its internal state changes. The object will appear to change its class.

Participants:

  • Context: Car
  • State: interface State
  • ConcreteState: On, Off

Strategy / Policy

DEFINITION: Define a family of algorithms, encapsulate each one, and make them interchangeable. Strategy lets the algorithm vary independently from clients that use it.

Participants:

  • Context: GPS (Coordinate)
  • Strategy: interface GoStrategy (Coordinate)
  • ConcreteStrategy: ByCar, ByWalk

Non-pattern participants:

  • Model: Coordinate

Template Method

DEFINITION: Define the skeleton of an algorithm in an operation, deferring some steps to subclasses. Template method lets subclasses redefine certain steps of an algorithm without changing the algorithms structure.

Participants:

  • AbstractClass: BoardGamePlayAlgorithm
  • ConcreteClass: ArcadiaQuestPlayAlgorithm, ParchisPlayAlgorithm

Visitor

DEFINITION: Represent an operation to be performed on the elements of an object structure. Visitor lets you define a new operation without changing the classes of the elements on which it operates.

Participants:

  • Visitor: interface Visitor
  • ConcreteVisitor: CashierVisitor
  • Element: interface Product
  • ConcreteElement: Coffee, Tuna
  • ObjectStructure (Composite participant in Composite pattern): ProductComposite
  • Client: Main