SlideShare une entreprise Scribd logo
1  sur  36
1
Design Patterns
• A design pattern is a documented best practice or core of a
solution that has been applied successfully in multiple
environments to solve a problem that recurs in a specific set of
situations
• Design patterns are recurring solutions to software design
problems you find again and again in real-world application
development
• Design patterns represent solutions to problems that arise
when developing software within a particular context (i.e.,
Pattern = problem/solution pair in context)
• Design patterns are standard solutions to common problems in
software design
2
Benefits & Drawbacks
Benefits:
• Design patterns enable large-scale reuse of software
architectures
• Patterns explicitly capture expert knowledge and design
tradeoffs, and make this expertise more widely available
• Patterns help improve developer communication
Drawbacks:
• Patterns do not lead to direct code reuse
• Patterns are deceptively simple
• Teams may suffer from pattern overload
• Patterns are validated by experience and discussion rather
than by automated testing
3
Kinds of Patterns
1. Analysis Patterns
for modeling requirements
2. Architectural Patterns
for major components of a software system
3. Design Patterns
for smaller software components
4. Programming Patterns
for specific languages
4
Design Pattern Catalog
CREATIONAL
PATTERNS
1. Factory
Method
2. Abstract
Factory
3. Builder
4. Prototype
5. Singleton
STRUCTURAL
PATTERNS
1. Adapter
2. Bridge
3. Composite
4. Decorator
5. Façade
6. Flyweight
7. Proxy
BEHAVIORAL
PATTERNS
1. Chain of
Responsibility
2. Command
3. Interpreter
4. Iterator
5. Mediator
6. Memento
7. Observer
8. State
9. Strategy
10. Template Method
11. Visitor
5
Factory Method
Definition
• Defines an interface for creating an object, but let subclasses
decide which class to instantiate. Factory Method lets a class
defer instantiation to subclasses
Problem & Context
• If an object needs to know the selection criteria to instantiate
an appropriate class, this results in a high degree of coupling.
Whenever the selection criteria change, every object that uses
the class must be changed correspondingly
Solution
• Encapsulate the functionality required to select and instantiate
the appropriate class. One way to do this is to create an
abstract class or an interface that declares the factory method.
Different subclasses can then implement the method in its
entirety
6
Abstract Factory
Definition
• Provides an interface for creating families of related or
dependent objects without specifying their concrete classes
Problem & Context
• Useful when an object wants to create an instance of a suite of
related and dependent classes without having to know which
specific concrete class is instantiated. In its absence, the
required implementation needs to be present wherever such
an instance is created
Solution
• Provide the necessary interface for creating instances.
Different concrete factories implement this interface. In Java, it
is an abstract class with its concrete subclasses as factories.
Each factory is responsible for creating and providing access
to the objects
7
Builder
Definition
• Separates the construction of a complex object from its
representation so that the same construction process can create
different representations
Problem & Context
• Object construction details are kept within the object as part of its
constructor. This may not be effective when the object being created
is complex and the object creation process produces different
representations of the object. The object can become bulky
(construction bloat) and less modular
Solution
• Move the construction logic out of the object class to separate
classes referred to as builder classes. A dedicated object referred to
as a Director, is responsible for invoking different builder methods
required for the construction of the final object. Different client objects
can make use of the Director object to create the required object
8
Prototype
Definition
• Specifies the kind of objects to create using a prototypical
instance and creates new objects by copying this prototype
Problem & Context
• When clients need to create a set of objects that are cost
prohibitive and alike or differ only in terms of their state, create
one object upfront and designate it as a prototype object or
simply make a copy of the prototype object
Solution
• Provide a way for clients to create a copy of the prototype
object. By default, all Java objects inherit the built in clone()
method that creates a clone of the original object
9
Singleton
Definition
• Ensures a class has only one instance and provide a global
point of access to it
Problem & Context
• Sometimes there may be a need to have one and only one
instance of a given class during the lifetime of an application.
This may be due to necessity or, more often, because only a
single instance of the class is sufficient
Solution
• Create a class with a method that creates a new instance of
the object if one does not exist. If one does exist, it returns a
reference to the object that already exists. To make sure that
the object cannot be instantiated any other way, the
constructor is made either private or protected
10
Singleton (Diagram)
11
Adapter
Definition
• Converts the interface of a class into another interface clients expect.
Adapter lets classes work together that couldn't otherwise because of
incompatible interfaces
Problem & Context
• Sometimes an existing class may provide the functionality required by
a client, but its interface may not be what the client expects. In such
cases, the existing interface needs to be converted into an interface
that the client expects, preserving the reusability of the existing class
Solution
• Define a wrapper class around the object with the incompatible
interface. The adapter provides the required interface expected by the
client. The implementation of the adapter interface converts client
requests into calls to the adaptee class interface
12
Bridge
Definition
• Decouples an abstraction from its implementation so that the two can
vary independently
Problem & Context
• An abstraction can be designed as an interface with one or more
concrete implementers. When subclassing the hierarchy, it could lead
to an exponential number of subclasses. And since both the interface
and its implementation are closely tied together, they cannot be
independently varied without affecting each other
Solution
• Put both the interfaces and the implementations into separate class
hierarchies. The Abstraction maintains an object reference of the
Implementer type. A client application can choose a desired
abstraction type from the Abstraction class hierarchy. The abstraction
object can then be configured with an instance of an appropriate
implementer from the Implementer class hierarchy
13
Composite
Definition
• Composes objects into tree structures to represent part-whole
hierarchies. Composites let clients treat individual objects and
compositions of objects uniformly
Problem & Context
• Useful in designing a common interface for both individual and
composite components so that client programs can view both the
individual components and groups of components uniformly
Solution
• Simulate a file system that consists of directories, files and an interface
called FileSystem with methods (such as getSize(), getComponent(),
addComponent()) common for both File and Directory components.
File and Directory classes are the implementers of the interface. A
typical client would create a set of FileSystem objects including a
hierarchy of file system objects. The client can treat both the Directory
and File objects identically
14
Composite (Diagram)
15
Decorator
Definition
• Attaches additional responsibilities to an object dynamically.
Decorators provide a flexible alternative to subclassing for extending
functionality
Problem & Context
• This pattern allows new/additional behavior to be added to an existing
method of an object dynamically. Since classes cannot be created at
runtime and it is typically not possible to predict what extensions will
be needed at design time, a new class would have to be made for
every possible combination. By contrast, decorators are objects,
created at runtime, and can be combined on a per-use basis
Solution
• Pass the original object as a parameter to the constructor of the
decorator, with the decorator implementing the new functionality. The
interface of the original object needs to be maintained by the decorator
16
Façade
Definition
• Provides a unified interface to a set of interfaces in a subsystem.
Façade defines a higher-level interface that makes the subsystem
easier to use
Problem & Context
• The Façade object takes up the responsibility of interacting with the
subsystem classes. In effect, clients interface with the façade to deal
with the subsystem. Consequently, the Façade pattern promotes a
weak coupling between a subsystem and its clients
Solution
• A façade should not be designed to provide any additional
functionality. Never return subsystem components from Façade
methods to clients
17
Façade (Diagram)
18
Flyweight
Definition
• Uses sharing to support large numbers of fine-grained objects
efficiently
Problem & Context
• This pattern suggests separating all the intrinsic common data into a
separate object referred to as a Flyweight object. The group of objects
being created can share the Flyweight object as it represents their
intrinsic state. This eliminates the need for storing the same invariant,
intrinsic information in every object; instead it is stored only once in
the form of a single Flyweight object
Solution
• Design flyweight as a singleton with a private constructor. The client
creates an object with the exclusive extrinsic data or sends the
extrinsic data as part of a method call to the Flyweight object. This
results in the creation of few objects with no duplication
19
Proxy
Definition
• Provides a surrogate or placeholder for another object to control access
to it
Problem & Context
• A client object can directly access a service provider object but
sometimes a client object may not have access to a target object by
normal means. The reasons could be: location, state of existence, and
special behavior of target object. Instead of having client objects to deal
with the special requirements for accessing the target object, the Proxy
pattern suggests using a separate object referred to as a proxy to
provide a means for different client objects to access the target object
in a normal, straightforward manner
Solution
• A proxy object should represent a single object. It provides access
control to the single target object, and offers the same interface
20
Proxy (Diagram)
21
Chain of Responsibility
Definition
• Avoids 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
Problem & Context
• When there is more than one object that can handle or fulfill a client
request, each of these potential handler objects can be arranged in
the form of a chain, with each object having a pointer to the next
object in the chain
Solution
• The order in which the objects form the chain can be decided
dynamically at runtime by the client. All potential handler objects
should provide a consistent interface. Neither the client object nor any
of the handler objects in the chain need to know which object will
actually fulfill the request
22
Command
Definition
• Encapsulates a request as an object, thereby letting you parameterize
clients with different requests, queue or log requests, and support
undoable operations
Problem & Context
• Used when there is a proliferation of similar methods and the interface
to implement an object becomes unwieldy – too many public methods
for other objects to call, an interface that is unworkable and always
changing
Solution
• Create an abstraction for the processing in response to client
requests by declaring a common interface to be implemented by
different concrete implementers referred to as Command objects. A
given Command object does not contain the actual implementation of
the functionality. Command objects make use of Receiver objects in
offering this functionality
23
Interpreter
Definition
• Given a language, defines a representation for its grammar along with
an interpreter that uses the representation to interpret sentences in the
language
Problem & Context
• Sometimes an application may process repeated similar requests that
are a combination of a set of grammar rules. These requests are
distinct but similar in the sense that they are composed using the
same set of rules. Instead of treating every distinct combination of
rules as a separate case, it may be beneficial for the application to
have the ability to interpret a generic combination of rules
Solution
• Design a class hierarchy to represent the set of grammar rules with
every class in the hierarchy representing a separate grammar rule. An
Interpreter module interprets the sentences constructed using the
class hierarchy and carries out the necessary operations
24
Iterator
Definition
• Provides a way to access the elements of an aggregate object
sequentially without exposing its underlying representation
Problem & Context
• The purpose of an iterator is to process every element of a container
while isolating the user from the internal structure of the container.
The container allows the user to treat it as if it were a simple
sequence or list while storing elements in any manner it wishes.
Iterators can provide a consistent way to iterate on data structures of
all kinds, making the code more readable, reusable, and less
sensitive to a change in the data structure
Solution
• In Java, the java.util.Iterator interface allows you to iterate container
classes. Each Iterator provides a next() and hasNext() method, and
may optionally support a remove() method. Iterators are created by
the method iterator() provided by the corresponding container class
25
Iterator (Diagram)
26
Mediator
Definition
• Defines an object that encapsulates how a set of objects interact.
Mediator promotes loose coupling by keeping objects from referring
to each other explicitly, and it lets you vary their interaction
independently
Problem & Context
• Objects interact with each other for the purpose of providing a
service. This interaction can be direct (point-to-point). As the number
of objects increases, the interaction can lead to a complex maze of
references among objects. Having an object directly referring to other
objects greatly reduces the scope for reuse
Solution
• The Mediator pattern suggests abstracting all object interaction
details into a separate class, referred to as a Mediator. The
interaction between any two different objects is routed through the
Mediator class. All objects send their messages to the mediator
27
Memento
Definition
• Without violating encapsulation, captures and externalizes an object's
internal state so that the object can be restored to this state later
Problem & Context
• The state of an object can be defined as the values of its attributes at
any given point of time. The Memento pattern is useful for designing a
mechanism to capture and store the state of an object so that, when
needed, the object can revert to its previous state. This is more like
an undo operation
Solution
• The object whose state needs to be captured is referred to as the
originator. The originator stores its attributes in a separate object
referred to as a Memento. A Memento object must hide the originator
variable values from all objects except the originator. A Memento
should be designed to provide restricted access to other objects while
the originator is allowed to access its internal state
28
Observer
Definition
• Defines a one-to-many dependency between objects so that when
one object changes state, all its dependents are notified and updated
automatically
Problem & Context
• Useful for designing a consistent communication model between a
set of dependent objects (observers) and an object that they are
dependent on (subject). This allows the observers to have their state
synchronized with the subject. Each of these observers needs to
know when the subject undergoes a change in its state
Solution
• The subject should provide an interface for registering and
unregistering change notifications. Observers should provide an
interface for receiving notifications from the subject
29
Observer (Diagram)
30
State
Definition
• Allows an object to alter its behavior when its internal state changes.
The object will appear to change its class
Problem & Context
• Useful in designing an efficient structure for a class, a typical instance
of which can exist in many different states and exhibit different behavior
depending on its state. In the case of an object of such a class, some or
all of its behavior is completely influenced by its current state. Such a
class is referred to as a Context class. A Context object can alter its
behavior when there is a change in its internal state and is also referred
as a Stateful object
Solution
• The State pattern suggests moving the state-specific behavior out of the
Context class into a set of separate classes referred to as State
classes. Each of the many different states in which a Context object can
exist can be mapped into a separate State class
31
Strategy
Definition
• Defines a family of algorithms, encapsulates each one, and makes them
interchangeable. Strategy lets the algorithm vary independently from
clients that use it
Problem & Context
• Useful when there is a set of related algorithms and a client object needs
to be able to dynamically pick and choose an algorithm that suits its
current need. The implementation of each of the algorithms is kept in a
separate class referred to as a strategy. An object that uses a Strategy
object is referred to as a context object. Changing the behavior of a
Context object is a matter of changing its Strategy object to the one that
implements the required algorithm
Solution
• All Strategy objects must be designed to offer the same interface. In Java,
this can be accomplished by designing each Strategy object either as an
implementer of a common interface or as a subclass of a common
abstract class that declares the required common interface
32
Template Method
Definition
• Defines 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 algorithm's structure
Problem & Context
• Used in situations when there is an algorithm, some steps of which could
be implemented in many different ways. The outline of the algorithm is
kept in a separate method referred to as a template method inside a
class, referred to as a template class, leaving out the specific
implementations of the variant portions of the algorithm to different
subclasses of this class
Solution
• The Template method can be a concrete, nonabstract method with calls
to other methods that represent different steps of the algorithm. Specific
implementations can be provided for these abstract methods inside a set
of concrete subclasses of the abstract Template class
33
Template Method (Diagram)
34
Visitor
Definition
• Represents 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
Problem & Context
• Visitor is useful in a heterogeneous collection of objects of a class
hierarchy. It allows operations to be defined without changing the
class of any of the objects in the collection. The Visitor pattern
suggests defining the operation in a separate class referred to as a
visitor class, which separates the operation from the object collection
on which it operates. For every new operation to be defined, a new
visitor class is created
Solution
• Every visitor class that operates on objects of the same set of classes
can be designed to implement a corresponding Visitor interface. A
typical Visitor interface declares a set of visit(ObjectType) methods,
one for each object type from the object collection. Each of these
methods is meant for processing instances of a specific class
35
Key Points
• Design Patterns are recurring solutions to software design
problems within a particular context
• There are 23 Design Patterns described by the GoF
• Design Patterns are categorized into Creational,
Structural, and Behavioral
• There are other Design Patterns in existence
36
References
• Design Patterns: Elements of Reusable Object-Oriented
Software
By: Erich Gamma, et al.
• Software Architecture Design Patterns in Java
By: Partha Kutchana
• The Design Patterns Java Companion
By: James W. Cooper
• http://www.dofactory.com/Patterns/Patterns.aspx
• http://www.cmcrossroads.com/bradapp/docs/patterns-intro.html
• http://en.wikipedia.org/wiki/Design_pattern_(computer_science)

Contenu connexe

Tendances

GoF Design patterns I: Introduction + Structural Patterns
GoF Design patterns I:   Introduction + Structural PatternsGoF Design patterns I:   Introduction + Structural Patterns
GoF Design patterns I: Introduction + Structural PatternsSameh Deabes
 
Lecture 5 Software Engineering and Design Design Patterns
Lecture 5 Software Engineering and Design Design PatternsLecture 5 Software Engineering and Design Design Patterns
Lecture 5 Software Engineering and Design Design Patternsop205
 
Structural patterns
Structural patternsStructural patterns
Structural patternsHimanshu
 
Gof design pattern
Gof design patternGof design pattern
Gof design patternnaveen kumar
 
Design Pattern For C# Part 1
Design Pattern For C# Part 1Design Pattern For C# Part 1
Design Pattern For C# Part 1Shahzad
 
Design patterns
Design patternsDesign patterns
Design patternsAlok Guha
 
GOF Design pattern with java
GOF Design pattern with javaGOF Design pattern with java
GOF Design pattern with javaRajiv Gupta
 
PATTERNS04 - Structural Design Patterns
PATTERNS04 - Structural Design PatternsPATTERNS04 - Structural Design Patterns
PATTERNS04 - Structural Design PatternsMichael Heron
 
Let us understand design pattern
Let us understand design patternLet us understand design pattern
Let us understand design patternMindfire Solutions
 
Design Pattern
Design PatternDesign Pattern
Design PatternHimanshu
 
Software design patterns ppt
Software design patterns pptSoftware design patterns ppt
Software design patterns pptmkruthika
 
P Training Presentation
P Training PresentationP Training Presentation
P Training PresentationGaurav Tyagi
 
Design pattern and their application
Design pattern and their applicationDesign pattern and their application
Design pattern and their applicationHiệp Tiến
 
J2EE Patterns
J2EE PatternsJ2EE Patterns
J2EE PatternsEmprovise
 

Tendances (20)

GoF Design patterns I: Introduction + Structural Patterns
GoF Design patterns I:   Introduction + Structural PatternsGoF Design patterns I:   Introduction + Structural Patterns
GoF Design patterns I: Introduction + Structural Patterns
 
Lecture 5 Software Engineering and Design Design Patterns
Lecture 5 Software Engineering and Design Design PatternsLecture 5 Software Engineering and Design Design Patterns
Lecture 5 Software Engineering and Design Design Patterns
 
Structural patterns
Structural patternsStructural patterns
Structural patterns
 
Gof design pattern
Gof design patternGof design pattern
Gof design pattern
 
Software Design Patterns
Software Design PatternsSoftware Design Patterns
Software Design Patterns
 
Design patterns
Design patternsDesign patterns
Design patterns
 
Design patterns
Design patternsDesign patterns
Design patterns
 
Design Pattern For C# Part 1
Design Pattern For C# Part 1Design Pattern For C# Part 1
Design Pattern For C# Part 1
 
Design patterns
Design patternsDesign patterns
Design patterns
 
GOF Design pattern with java
GOF Design pattern with javaGOF Design pattern with java
GOF Design pattern with java
 
PATTERNS04 - Structural Design Patterns
PATTERNS04 - Structural Design PatternsPATTERNS04 - Structural Design Patterns
PATTERNS04 - Structural Design Patterns
 
Let us understand design pattern
Let us understand design patternLet us understand design pattern
Let us understand design pattern
 
Design Patterns (Examples in .NET)
Design Patterns (Examples in .NET)Design Patterns (Examples in .NET)
Design Patterns (Examples in .NET)
 
Design Pattern
Design PatternDesign Pattern
Design Pattern
 
Design patterns
Design patternsDesign patterns
Design patterns
 
Software design patterns ppt
Software design patterns pptSoftware design patterns ppt
Software design patterns ppt
 
Design Patterns
Design PatternsDesign Patterns
Design Patterns
 
P Training Presentation
P Training PresentationP Training Presentation
P Training Presentation
 
Design pattern and their application
Design pattern and their applicationDesign pattern and their application
Design pattern and their application
 
J2EE Patterns
J2EE PatternsJ2EE Patterns
J2EE Patterns
 

Similaire à Design Patterns Overview

UNIT IV DESIGN PATTERNS.pptx
UNIT IV DESIGN PATTERNS.pptxUNIT IV DESIGN PATTERNS.pptx
UNIT IV DESIGN PATTERNS.pptxanguraju1
 
Creational Design Patterns.pptx
Creational Design Patterns.pptxCreational Design Patterns.pptx
Creational Design Patterns.pptxSachin Patidar
 
Design patterns Structural
Design patterns StructuralDesign patterns Structural
Design patterns StructuralUMAR ALI
 
Chapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.pptChapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.pptRushikeshChikane1
 
Chapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.pptChapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.pptRushikeshChikane2
 
Patterns (contd)Software Development ProcessDesign patte.docx
Patterns (contd)Software Development ProcessDesign patte.docxPatterns (contd)Software Development ProcessDesign patte.docx
Patterns (contd)Software Development ProcessDesign patte.docxdanhaley45372
 
Design Pattern lecture 2
Design Pattern lecture 2Design Pattern lecture 2
Design Pattern lecture 2Julie Iskander
 
Software Patterns
Software PatternsSoftware Patterns
Software Patternsbonej010
 
Design Pattern Notes: Nagpur University
Design Pattern Notes: Nagpur UniversityDesign Pattern Notes: Nagpur University
Design Pattern Notes: Nagpur UniversityShubham Narkhede
 
.net Based Component Technologies
.net Based Component Technologies.net Based Component Technologies
.net Based Component Technologiesprakashk453625
 
common design patterns summary.pdf
common design patterns summary.pdfcommon design patterns summary.pdf
common design patterns summary.pdfNikolayRaychev2
 
Introduction to Design Patterns in Javascript
Introduction to Design Patterns in JavascriptIntroduction to Design Patterns in Javascript
Introduction to Design Patterns in JavascriptSanthosh Kumar Srinivasan
 

Similaire à Design Patterns Overview (20)

UNIT IV DESIGN PATTERNS.pptx
UNIT IV DESIGN PATTERNS.pptxUNIT IV DESIGN PATTERNS.pptx
UNIT IV DESIGN PATTERNS.pptx
 
Creational Design Patterns.pptx
Creational Design Patterns.pptxCreational Design Patterns.pptx
Creational Design Patterns.pptx
 
Design patterns Structural
Design patterns StructuralDesign patterns Structural
Design patterns Structural
 
Chapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.pptChapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.ppt
 
Chapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.pptChapter 4_Introduction to Patterns.ppt
Chapter 4_Introduction to Patterns.ppt
 
Patterns (contd)Software Development ProcessDesign patte.docx
Patterns (contd)Software Development ProcessDesign patte.docxPatterns (contd)Software Development ProcessDesign patte.docx
Patterns (contd)Software Development ProcessDesign patte.docx
 
Decorator design pattern
Decorator design patternDecorator design pattern
Decorator design pattern
 
Design patterns
Design patternsDesign patterns
Design patterns
 
Design patterns
Design patternsDesign patterns
Design patterns
 
Design Pattern lecture 2
Design Pattern lecture 2Design Pattern lecture 2
Design Pattern lecture 2
 
Software Patterns
Software PatternsSoftware Patterns
Software Patterns
 
Design Pattern Notes: Nagpur University
Design Pattern Notes: Nagpur UniversityDesign Pattern Notes: Nagpur University
Design Pattern Notes: Nagpur University
 
.net Based Component Technologies
.net Based Component Technologies.net Based Component Technologies
.net Based Component Technologies
 
Design pattern
Design patternDesign pattern
Design pattern
 
Design_Patterns_Dr.CM.ppt
Design_Patterns_Dr.CM.pptDesign_Patterns_Dr.CM.ppt
Design_Patterns_Dr.CM.ppt
 
common design patterns summary.pdf
common design patterns summary.pdfcommon design patterns summary.pdf
common design patterns summary.pdf
 
Encapsulation
EncapsulationEncapsulation
Encapsulation
 
Patterns
PatternsPatterns
Patterns
 
Facadepattern
FacadepatternFacadepattern
Facadepattern
 
Introduction to Design Patterns in Javascript
Introduction to Design Patterns in JavascriptIntroduction to Design Patterns in Javascript
Introduction to Design Patterns in Javascript
 

Plus de stanbridge

Micro Lab 3 Lecture
Micro Lab 3 LectureMicro Lab 3 Lecture
Micro Lab 3 Lecturestanbridge
 
Creating a poster v2
Creating a poster v2Creating a poster v2
Creating a poster v2stanbridge
 
Creating a poster
Creating a posterCreating a poster
Creating a posterstanbridge
 
OT 5018 Thesis Dissemination
OT 5018 Thesis DisseminationOT 5018 Thesis Dissemination
OT 5018 Thesis Disseminationstanbridge
 
Ot5101 005 week 5
Ot5101 005 week 5Ot5101 005 week 5
Ot5101 005 week 5stanbridge
 
Ot5101 005 week4
Ot5101 005 week4Ot5101 005 week4
Ot5101 005 week4stanbridge
 
Compliance, motivation, and health behaviors
Compliance, motivation, and health behaviors Compliance, motivation, and health behaviors
Compliance, motivation, and health behaviors stanbridge
 
Ch 5 developmental stages of the learner
Ch 5   developmental stages of the learnerCh 5   developmental stages of the learner
Ch 5 developmental stages of the learnerstanbridge
 
OT 5101 week2 theory policy
OT 5101 week2 theory policyOT 5101 week2 theory policy
OT 5101 week2 theory policystanbridge
 
OT 5101 week3 planning needs assessment
OT 5101 week3 planning needs assessmentOT 5101 week3 planning needs assessment
OT 5101 week3 planning needs assessmentstanbridge
 
NUR 304 Chapter005
NUR 304 Chapter005NUR 304 Chapter005
NUR 304 Chapter005stanbridge
 
NUR 3043 Chapter007
NUR 3043 Chapter007NUR 3043 Chapter007
NUR 3043 Chapter007stanbridge
 
NUR 3043 Chapter006
NUR 3043 Chapter006NUR 3043 Chapter006
NUR 3043 Chapter006stanbridge
 
NUR 3043 Chapter004
NUR 3043 Chapter004NUR 3043 Chapter004
NUR 3043 Chapter004stanbridge
 
3043 Chapter009
3043 Chapter0093043 Chapter009
3043 Chapter009stanbridge
 
3043 Chapter008
 3043 Chapter008 3043 Chapter008
3043 Chapter008stanbridge
 
Melnyk ppt chapter_21
Melnyk ppt chapter_21Melnyk ppt chapter_21
Melnyk ppt chapter_21stanbridge
 
Melnyk ppt chapter_22
Melnyk ppt chapter_22Melnyk ppt chapter_22
Melnyk ppt chapter_22stanbridge
 

Plus de stanbridge (20)

Micro Lab 3 Lecture
Micro Lab 3 LectureMicro Lab 3 Lecture
Micro Lab 3 Lecture
 
Creating a poster v2
Creating a poster v2Creating a poster v2
Creating a poster v2
 
Creating a poster
Creating a posterCreating a poster
Creating a poster
 
Sample poster
Sample posterSample poster
Sample poster
 
OT 5018 Thesis Dissemination
OT 5018 Thesis DisseminationOT 5018 Thesis Dissemination
OT 5018 Thesis Dissemination
 
Ot5101 005 week 5
Ot5101 005 week 5Ot5101 005 week 5
Ot5101 005 week 5
 
Ot5101 005 week4
Ot5101 005 week4Ot5101 005 week4
Ot5101 005 week4
 
Compliance, motivation, and health behaviors
Compliance, motivation, and health behaviors Compliance, motivation, and health behaviors
Compliance, motivation, and health behaviors
 
Ch 5 developmental stages of the learner
Ch 5   developmental stages of the learnerCh 5   developmental stages of the learner
Ch 5 developmental stages of the learner
 
OT 5101 week2 theory policy
OT 5101 week2 theory policyOT 5101 week2 theory policy
OT 5101 week2 theory policy
 
OT 5101 week3 planning needs assessment
OT 5101 week3 planning needs assessmentOT 5101 week3 planning needs assessment
OT 5101 week3 planning needs assessment
 
Ot5101 week1
Ot5101 week1Ot5101 week1
Ot5101 week1
 
NUR 304 Chapter005
NUR 304 Chapter005NUR 304 Chapter005
NUR 304 Chapter005
 
NUR 3043 Chapter007
NUR 3043 Chapter007NUR 3043 Chapter007
NUR 3043 Chapter007
 
NUR 3043 Chapter006
NUR 3043 Chapter006NUR 3043 Chapter006
NUR 3043 Chapter006
 
NUR 3043 Chapter004
NUR 3043 Chapter004NUR 3043 Chapter004
NUR 3043 Chapter004
 
3043 Chapter009
3043 Chapter0093043 Chapter009
3043 Chapter009
 
3043 Chapter008
 3043 Chapter008 3043 Chapter008
3043 Chapter008
 
Melnyk ppt chapter_21
Melnyk ppt chapter_21Melnyk ppt chapter_21
Melnyk ppt chapter_21
 
Melnyk ppt chapter_22
Melnyk ppt chapter_22Melnyk ppt chapter_22
Melnyk ppt chapter_22
 

Dernier

What is Model Inheritance in Odoo 17 ERP
What is Model Inheritance in Odoo 17 ERPWhat is Model Inheritance in Odoo 17 ERP
What is Model Inheritance in Odoo 17 ERPCeline George
 
INTRODUCTION TO CATHOLIC CHRISTOLOGY.pptx
INTRODUCTION TO CATHOLIC CHRISTOLOGY.pptxINTRODUCTION TO CATHOLIC CHRISTOLOGY.pptx
INTRODUCTION TO CATHOLIC CHRISTOLOGY.pptxHumphrey A Beña
 
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...JhezDiaz1
 
How to Add Barcode on PDF Report in Odoo 17
How to Add Barcode on PDF Report in Odoo 17How to Add Barcode on PDF Report in Odoo 17
How to Add Barcode on PDF Report in Odoo 17Celine George
 
Procuring digital preservation CAN be quick and painless with our new dynamic...
Procuring digital preservation CAN be quick and painless with our new dynamic...Procuring digital preservation CAN be quick and painless with our new dynamic...
Procuring digital preservation CAN be quick and painless with our new dynamic...Jisc
 
Earth Day Presentation wow hello nice great
Earth Day Presentation wow hello nice greatEarth Day Presentation wow hello nice great
Earth Day Presentation wow hello nice greatYousafMalik24
 
GRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTS
GRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTSGRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTS
GRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTSJoshuaGantuangco2
 
AMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdf
AMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdfAMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdf
AMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdfphamnguyenenglishnb
 
Barangay Council for the Protection of Children (BCPC) Orientation.pptx
Barangay Council for the Protection of Children (BCPC) Orientation.pptxBarangay Council for the Protection of Children (BCPC) Orientation.pptx
Barangay Council for the Protection of Children (BCPC) Orientation.pptxCarlos105
 
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptxECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptxiammrhaywood
 
Grade 9 Q4-MELC1-Active and Passive Voice.pptx
Grade 9 Q4-MELC1-Active and Passive Voice.pptxGrade 9 Q4-MELC1-Active and Passive Voice.pptx
Grade 9 Q4-MELC1-Active and Passive Voice.pptxChelloAnnAsuncion2
 
USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...
USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...
USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...Postal Advocate Inc.
 
ANG SEKTOR NG agrikultura.pptx QUARTER 4
ANG SEKTOR NG agrikultura.pptx QUARTER 4ANG SEKTOR NG agrikultura.pptx QUARTER 4
ANG SEKTOR NG agrikultura.pptx QUARTER 4MiaBumagat1
 
Influencing policy (training slides from Fast Track Impact)
Influencing policy (training slides from Fast Track Impact)Influencing policy (training slides from Fast Track Impact)
Influencing policy (training slides from Fast Track Impact)Mark Reed
 
THEORIES OF ORGANIZATION-PUBLIC ADMINISTRATION
THEORIES OF ORGANIZATION-PUBLIC ADMINISTRATIONTHEORIES OF ORGANIZATION-PUBLIC ADMINISTRATION
THEORIES OF ORGANIZATION-PUBLIC ADMINISTRATIONHumphrey A Beña
 
4.18.24 Movement Legacies, Reflection, and Review.pptx
4.18.24 Movement Legacies, Reflection, and Review.pptx4.18.24 Movement Legacies, Reflection, and Review.pptx
4.18.24 Movement Legacies, Reflection, and Review.pptxmary850239
 

Dernier (20)

What is Model Inheritance in Odoo 17 ERP
What is Model Inheritance in Odoo 17 ERPWhat is Model Inheritance in Odoo 17 ERP
What is Model Inheritance in Odoo 17 ERP
 
INTRODUCTION TO CATHOLIC CHRISTOLOGY.pptx
INTRODUCTION TO CATHOLIC CHRISTOLOGY.pptxINTRODUCTION TO CATHOLIC CHRISTOLOGY.pptx
INTRODUCTION TO CATHOLIC CHRISTOLOGY.pptx
 
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
 
How to Add Barcode on PDF Report in Odoo 17
How to Add Barcode on PDF Report in Odoo 17How to Add Barcode on PDF Report in Odoo 17
How to Add Barcode on PDF Report in Odoo 17
 
Procuring digital preservation CAN be quick and painless with our new dynamic...
Procuring digital preservation CAN be quick and painless with our new dynamic...Procuring digital preservation CAN be quick and painless with our new dynamic...
Procuring digital preservation CAN be quick and painless with our new dynamic...
 
Earth Day Presentation wow hello nice great
Earth Day Presentation wow hello nice greatEarth Day Presentation wow hello nice great
Earth Day Presentation wow hello nice great
 
GRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTS
GRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTSGRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTS
GRADE 4 - SUMMATIVE TEST QUARTER 4 ALL SUBJECTS
 
AMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdf
AMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdfAMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdf
AMERICAN LANGUAGE HUB_Level2_Student'sBook_Answerkey.pdf
 
Barangay Council for the Protection of Children (BCPC) Orientation.pptx
Barangay Council for the Protection of Children (BCPC) Orientation.pptxBarangay Council for the Protection of Children (BCPC) Orientation.pptx
Barangay Council for the Protection of Children (BCPC) Orientation.pptx
 
FINALS_OF_LEFT_ON_C'N_EL_DORADO_2024.pptx
FINALS_OF_LEFT_ON_C'N_EL_DORADO_2024.pptxFINALS_OF_LEFT_ON_C'N_EL_DORADO_2024.pptx
FINALS_OF_LEFT_ON_C'N_EL_DORADO_2024.pptx
 
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptxECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
 
YOUVE_GOT_EMAIL_PRELIMS_EL_DORADO_2024.pptx
YOUVE_GOT_EMAIL_PRELIMS_EL_DORADO_2024.pptxYOUVE_GOT_EMAIL_PRELIMS_EL_DORADO_2024.pptx
YOUVE_GOT_EMAIL_PRELIMS_EL_DORADO_2024.pptx
 
Grade 9 Q4-MELC1-Active and Passive Voice.pptx
Grade 9 Q4-MELC1-Active and Passive Voice.pptxGrade 9 Q4-MELC1-Active and Passive Voice.pptx
Grade 9 Q4-MELC1-Active and Passive Voice.pptx
 
Model Call Girl in Tilak Nagar Delhi reach out to us at 🔝9953056974🔝
Model Call Girl in Tilak Nagar Delhi reach out to us at 🔝9953056974🔝Model Call Girl in Tilak Nagar Delhi reach out to us at 🔝9953056974🔝
Model Call Girl in Tilak Nagar Delhi reach out to us at 🔝9953056974🔝
 
USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...
USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...
USPS® Forced Meter Migration - How to Know if Your Postage Meter Will Soon be...
 
ANG SEKTOR NG agrikultura.pptx QUARTER 4
ANG SEKTOR NG agrikultura.pptx QUARTER 4ANG SEKTOR NG agrikultura.pptx QUARTER 4
ANG SEKTOR NG agrikultura.pptx QUARTER 4
 
Influencing policy (training slides from Fast Track Impact)
Influencing policy (training slides from Fast Track Impact)Influencing policy (training slides from Fast Track Impact)
Influencing policy (training slides from Fast Track Impact)
 
THEORIES OF ORGANIZATION-PUBLIC ADMINISTRATION
THEORIES OF ORGANIZATION-PUBLIC ADMINISTRATIONTHEORIES OF ORGANIZATION-PUBLIC ADMINISTRATION
THEORIES OF ORGANIZATION-PUBLIC ADMINISTRATION
 
Raw materials used in Herbal Cosmetics.pptx
Raw materials used in Herbal Cosmetics.pptxRaw materials used in Herbal Cosmetics.pptx
Raw materials used in Herbal Cosmetics.pptx
 
4.18.24 Movement Legacies, Reflection, and Review.pptx
4.18.24 Movement Legacies, Reflection, and Review.pptx4.18.24 Movement Legacies, Reflection, and Review.pptx
4.18.24 Movement Legacies, Reflection, and Review.pptx
 

Design Patterns Overview

  • 1. 1 Design Patterns • A design pattern is a documented best practice or core of a solution that has been applied successfully in multiple environments to solve a problem that recurs in a specific set of situations • Design patterns are recurring solutions to software design problems you find again and again in real-world application development • Design patterns represent solutions to problems that arise when developing software within a particular context (i.e., Pattern = problem/solution pair in context) • Design patterns are standard solutions to common problems in software design
  • 2. 2 Benefits & Drawbacks Benefits: • Design patterns enable large-scale reuse of software architectures • Patterns explicitly capture expert knowledge and design tradeoffs, and make this expertise more widely available • Patterns help improve developer communication Drawbacks: • Patterns do not lead to direct code reuse • Patterns are deceptively simple • Teams may suffer from pattern overload • Patterns are validated by experience and discussion rather than by automated testing
  • 3. 3 Kinds of Patterns 1. Analysis Patterns for modeling requirements 2. Architectural Patterns for major components of a software system 3. Design Patterns for smaller software components 4. Programming Patterns for specific languages
  • 4. 4 Design Pattern Catalog CREATIONAL PATTERNS 1. Factory Method 2. Abstract Factory 3. Builder 4. Prototype 5. Singleton STRUCTURAL PATTERNS 1. Adapter 2. Bridge 3. Composite 4. Decorator 5. Façade 6. Flyweight 7. Proxy BEHAVIORAL PATTERNS 1. Chain of Responsibility 2. Command 3. Interpreter 4. Iterator 5. Mediator 6. Memento 7. Observer 8. State 9. Strategy 10. Template Method 11. Visitor
  • 5. 5 Factory Method Definition • Defines an interface for creating an object, but let subclasses decide which class to instantiate. Factory Method lets a class defer instantiation to subclasses Problem & Context • If an object needs to know the selection criteria to instantiate an appropriate class, this results in a high degree of coupling. Whenever the selection criteria change, every object that uses the class must be changed correspondingly Solution • Encapsulate the functionality required to select and instantiate the appropriate class. One way to do this is to create an abstract class or an interface that declares the factory method. Different subclasses can then implement the method in its entirety
  • 6. 6 Abstract Factory Definition • Provides an interface for creating families of related or dependent objects without specifying their concrete classes Problem & Context • Useful when an object wants to create an instance of a suite of related and dependent classes without having to know which specific concrete class is instantiated. In its absence, the required implementation needs to be present wherever such an instance is created Solution • Provide the necessary interface for creating instances. Different concrete factories implement this interface. In Java, it is an abstract class with its concrete subclasses as factories. Each factory is responsible for creating and providing access to the objects
  • 7. 7 Builder Definition • Separates the construction of a complex object from its representation so that the same construction process can create different representations Problem & Context • Object construction details are kept within the object as part of its constructor. This may not be effective when the object being created is complex and the object creation process produces different representations of the object. The object can become bulky (construction bloat) and less modular Solution • Move the construction logic out of the object class to separate classes referred to as builder classes. A dedicated object referred to as a Director, is responsible for invoking different builder methods required for the construction of the final object. Different client objects can make use of the Director object to create the required object
  • 8. 8 Prototype Definition • Specifies the kind of objects to create using a prototypical instance and creates new objects by copying this prototype Problem & Context • When clients need to create a set of objects that are cost prohibitive and alike or differ only in terms of their state, create one object upfront and designate it as a prototype object or simply make a copy of the prototype object Solution • Provide a way for clients to create a copy of the prototype object. By default, all Java objects inherit the built in clone() method that creates a clone of the original object
  • 9. 9 Singleton Definition • Ensures a class has only one instance and provide a global point of access to it Problem & Context • Sometimes there may be a need to have one and only one instance of a given class during the lifetime of an application. This may be due to necessity or, more often, because only a single instance of the class is sufficient Solution • Create a class with a method that creates a new instance of the object if one does not exist. If one does exist, it returns a reference to the object that already exists. To make sure that the object cannot be instantiated any other way, the constructor is made either private or protected
  • 11. 11 Adapter Definition • Converts the interface of a class into another interface clients expect. Adapter lets classes work together that couldn't otherwise because of incompatible interfaces Problem & Context • Sometimes an existing class may provide the functionality required by a client, but its interface may not be what the client expects. In such cases, the existing interface needs to be converted into an interface that the client expects, preserving the reusability of the existing class Solution • Define a wrapper class around the object with the incompatible interface. The adapter provides the required interface expected by the client. The implementation of the adapter interface converts client requests into calls to the adaptee class interface
  • 12. 12 Bridge Definition • Decouples an abstraction from its implementation so that the two can vary independently Problem & Context • An abstraction can be designed as an interface with one or more concrete implementers. When subclassing the hierarchy, it could lead to an exponential number of subclasses. And since both the interface and its implementation are closely tied together, they cannot be independently varied without affecting each other Solution • Put both the interfaces and the implementations into separate class hierarchies. The Abstraction maintains an object reference of the Implementer type. A client application can choose a desired abstraction type from the Abstraction class hierarchy. The abstraction object can then be configured with an instance of an appropriate implementer from the Implementer class hierarchy
  • 13. 13 Composite Definition • Composes objects into tree structures to represent part-whole hierarchies. Composites let clients treat individual objects and compositions of objects uniformly Problem & Context • Useful in designing a common interface for both individual and composite components so that client programs can view both the individual components and groups of components uniformly Solution • Simulate a file system that consists of directories, files and an interface called FileSystem with methods (such as getSize(), getComponent(), addComponent()) common for both File and Directory components. File and Directory classes are the implementers of the interface. A typical client would create a set of FileSystem objects including a hierarchy of file system objects. The client can treat both the Directory and File objects identically
  • 15. 15 Decorator Definition • Attaches additional responsibilities to an object dynamically. Decorators provide a flexible alternative to subclassing for extending functionality Problem & Context • This pattern allows new/additional behavior to be added to an existing method of an object dynamically. Since classes cannot be created at runtime and it is typically not possible to predict what extensions will be needed at design time, a new class would have to be made for every possible combination. By contrast, decorators are objects, created at runtime, and can be combined on a per-use basis Solution • Pass the original object as a parameter to the constructor of the decorator, with the decorator implementing the new functionality. The interface of the original object needs to be maintained by the decorator
  • 16. 16 Façade Definition • Provides a unified interface to a set of interfaces in a subsystem. Façade defines a higher-level interface that makes the subsystem easier to use Problem & Context • The Façade object takes up the responsibility of interacting with the subsystem classes. In effect, clients interface with the façade to deal with the subsystem. Consequently, the Façade pattern promotes a weak coupling between a subsystem and its clients Solution • A façade should not be designed to provide any additional functionality. Never return subsystem components from Façade methods to clients
  • 18. 18 Flyweight Definition • Uses sharing to support large numbers of fine-grained objects efficiently Problem & Context • This pattern suggests separating all the intrinsic common data into a separate object referred to as a Flyweight object. The group of objects being created can share the Flyweight object as it represents their intrinsic state. This eliminates the need for storing the same invariant, intrinsic information in every object; instead it is stored only once in the form of a single Flyweight object Solution • Design flyweight as a singleton with a private constructor. The client creates an object with the exclusive extrinsic data or sends the extrinsic data as part of a method call to the Flyweight object. This results in the creation of few objects with no duplication
  • 19. 19 Proxy Definition • Provides a surrogate or placeholder for another object to control access to it Problem & Context • A client object can directly access a service provider object but sometimes a client object may not have access to a target object by normal means. The reasons could be: location, state of existence, and special behavior of target object. Instead of having client objects to deal with the special requirements for accessing the target object, the Proxy pattern suggests using a separate object referred to as a proxy to provide a means for different client objects to access the target object in a normal, straightforward manner Solution • A proxy object should represent a single object. It provides access control to the single target object, and offers the same interface
  • 21. 21 Chain of Responsibility Definition • Avoids 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 Problem & Context • When there is more than one object that can handle or fulfill a client request, each of these potential handler objects can be arranged in the form of a chain, with each object having a pointer to the next object in the chain Solution • The order in which the objects form the chain can be decided dynamically at runtime by the client. All potential handler objects should provide a consistent interface. Neither the client object nor any of the handler objects in the chain need to know which object will actually fulfill the request
  • 22. 22 Command Definition • Encapsulates a request as an object, thereby letting you parameterize clients with different requests, queue or log requests, and support undoable operations Problem & Context • Used when there is a proliferation of similar methods and the interface to implement an object becomes unwieldy – too many public methods for other objects to call, an interface that is unworkable and always changing Solution • Create an abstraction for the processing in response to client requests by declaring a common interface to be implemented by different concrete implementers referred to as Command objects. A given Command object does not contain the actual implementation of the functionality. Command objects make use of Receiver objects in offering this functionality
  • 23. 23 Interpreter Definition • Given a language, defines a representation for its grammar along with an interpreter that uses the representation to interpret sentences in the language Problem & Context • Sometimes an application may process repeated similar requests that are a combination of a set of grammar rules. These requests are distinct but similar in the sense that they are composed using the same set of rules. Instead of treating every distinct combination of rules as a separate case, it may be beneficial for the application to have the ability to interpret a generic combination of rules Solution • Design a class hierarchy to represent the set of grammar rules with every class in the hierarchy representing a separate grammar rule. An Interpreter module interprets the sentences constructed using the class hierarchy and carries out the necessary operations
  • 24. 24 Iterator Definition • Provides a way to access the elements of an aggregate object sequentially without exposing its underlying representation Problem & Context • The purpose of an iterator is to process every element of a container while isolating the user from the internal structure of the container. The container allows the user to treat it as if it were a simple sequence or list while storing elements in any manner it wishes. Iterators can provide a consistent way to iterate on data structures of all kinds, making the code more readable, reusable, and less sensitive to a change in the data structure Solution • In Java, the java.util.Iterator interface allows you to iterate container classes. Each Iterator provides a next() and hasNext() method, and may optionally support a remove() method. Iterators are created by the method iterator() provided by the corresponding container class
  • 26. 26 Mediator Definition • Defines an object that encapsulates how a set of objects interact. Mediator promotes loose coupling by keeping objects from referring to each other explicitly, and it lets you vary their interaction independently Problem & Context • Objects interact with each other for the purpose of providing a service. This interaction can be direct (point-to-point). As the number of objects increases, the interaction can lead to a complex maze of references among objects. Having an object directly referring to other objects greatly reduces the scope for reuse Solution • The Mediator pattern suggests abstracting all object interaction details into a separate class, referred to as a Mediator. The interaction between any two different objects is routed through the Mediator class. All objects send their messages to the mediator
  • 27. 27 Memento Definition • Without violating encapsulation, captures and externalizes an object's internal state so that the object can be restored to this state later Problem & Context • The state of an object can be defined as the values of its attributes at any given point of time. The Memento pattern is useful for designing a mechanism to capture and store the state of an object so that, when needed, the object can revert to its previous state. This is more like an undo operation Solution • The object whose state needs to be captured is referred to as the originator. The originator stores its attributes in a separate object referred to as a Memento. A Memento object must hide the originator variable values from all objects except the originator. A Memento should be designed to provide restricted access to other objects while the originator is allowed to access its internal state
  • 28. 28 Observer Definition • Defines a one-to-many dependency between objects so that when one object changes state, all its dependents are notified and updated automatically Problem & Context • Useful for designing a consistent communication model between a set of dependent objects (observers) and an object that they are dependent on (subject). This allows the observers to have their state synchronized with the subject. Each of these observers needs to know when the subject undergoes a change in its state Solution • The subject should provide an interface for registering and unregistering change notifications. Observers should provide an interface for receiving notifications from the subject
  • 30. 30 State Definition • Allows an object to alter its behavior when its internal state changes. The object will appear to change its class Problem & Context • Useful in designing an efficient structure for a class, a typical instance of which can exist in many different states and exhibit different behavior depending on its state. In the case of an object of such a class, some or all of its behavior is completely influenced by its current state. Such a class is referred to as a Context class. A Context object can alter its behavior when there is a change in its internal state and is also referred as a Stateful object Solution • The State pattern suggests moving the state-specific behavior out of the Context class into a set of separate classes referred to as State classes. Each of the many different states in which a Context object can exist can be mapped into a separate State class
  • 31. 31 Strategy Definition • Defines a family of algorithms, encapsulates each one, and makes them interchangeable. Strategy lets the algorithm vary independently from clients that use it Problem & Context • Useful when there is a set of related algorithms and a client object needs to be able to dynamically pick and choose an algorithm that suits its current need. The implementation of each of the algorithms is kept in a separate class referred to as a strategy. An object that uses a Strategy object is referred to as a context object. Changing the behavior of a Context object is a matter of changing its Strategy object to the one that implements the required algorithm Solution • All Strategy objects must be designed to offer the same interface. In Java, this can be accomplished by designing each Strategy object either as an implementer of a common interface or as a subclass of a common abstract class that declares the required common interface
  • 32. 32 Template Method Definition • Defines 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 algorithm's structure Problem & Context • Used in situations when there is an algorithm, some steps of which could be implemented in many different ways. The outline of the algorithm is kept in a separate method referred to as a template method inside a class, referred to as a template class, leaving out the specific implementations of the variant portions of the algorithm to different subclasses of this class Solution • The Template method can be a concrete, nonabstract method with calls to other methods that represent different steps of the algorithm. Specific implementations can be provided for these abstract methods inside a set of concrete subclasses of the abstract Template class
  • 34. 34 Visitor Definition • Represents 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 Problem & Context • Visitor is useful in a heterogeneous collection of objects of a class hierarchy. It allows operations to be defined without changing the class of any of the objects in the collection. The Visitor pattern suggests defining the operation in a separate class referred to as a visitor class, which separates the operation from the object collection on which it operates. For every new operation to be defined, a new visitor class is created Solution • Every visitor class that operates on objects of the same set of classes can be designed to implement a corresponding Visitor interface. A typical Visitor interface declares a set of visit(ObjectType) methods, one for each object type from the object collection. Each of these methods is meant for processing instances of a specific class
  • 35. 35 Key Points • Design Patterns are recurring solutions to software design problems within a particular context • There are 23 Design Patterns described by the GoF • Design Patterns are categorized into Creational, Structural, and Behavioral • There are other Design Patterns in existence
  • 36. 36 References • Design Patterns: Elements of Reusable Object-Oriented Software By: Erich Gamma, et al. • Software Architecture Design Patterns in Java By: Partha Kutchana • The Design Patterns Java Companion By: James W. Cooper • http://www.dofactory.com/Patterns/Patterns.aspx • http://www.cmcrossroads.com/bradapp/docs/patterns-intro.html • http://en.wikipedia.org/wiki/Design_pattern_(computer_science)