CS 4240: Introduction to Design Patterns Readings: Chap. 5 of Design Patterns Explained Also, Chap. 6 and 7 Also, on-line info on Composite pattern (and.

Slides:



Advertisements
Similar presentations
Design Patterns.
Advertisements

©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Software Design l Objectives To explain how a software design may be represented.
Design Patterns Section 7.1 (JIA’s) Section (till page 259) (JIA’s) Section 7.2.2(JIA’s) Section (JIA’s)
Design Patterns CMPS Design Patterns Consider previous solutions to problems similar to any new problem ▫ must have some characteristics in common.
The Bridge Pattern.. Intent Decouple an abstraction from its implementation so that the two can vary independently Also known as: Handle/Body.
March Ron McFadyen1 Design Patterns In software engineering, a design pattern is a generally repeatable solution to a commonly-occurring problem.
Chapter 6: Using Design Patterns
Dept. of Computer Engineering, Amirkabir University of Tech. 1 Design Patterns Dr. Noorhosseini Introduction.
Design Patterns CS is not simply about programming
Chapter 8 Object Design Reuse and Patterns. Finding Objects The hardest problems in object-oriented system development are: –Identifying objects –Decomposing.
The Composite Pattern.. Composite Pattern Intent –Compose objects into tree structures to represent part-whole hierarchies. –Composite lets clients treat.
PRESENTED BY SANGEETA MEHTA EECS810 UNIVERSITY OF KANSAS OCTOBER 2008 Design Patterns.
1 An introduction to design patterns Based on material produced by John Vlissides and Douglas C. Schmidt.
Design Patterns CS 124 Reference: Gamma et al (“Gang-of-4”), Design Patterns.
Programming With Java ICS201 University Of Hail1 Chapter 12 UML and Patterns.
Design Patterns Discussion of pages: xi-11 Sections: Preface, Forward, Chapter
Design Patterns.
CS 4240: Bridge and Abstract Factory Readings:  Chap. 10 and 11 Readings:  Chap. 10 and 11.
Design Dan Fleck CS 421 George Mason University. What is the design phase? Analysis phase describes what the system should do Analysis has provided a.
Design patterns. What is a design pattern? Christopher Alexander: «The pattern describes a problem which again and again occurs in the work, as well as.
SOFTWARE DESIGN AND ARCHITECTURE
An Introduction to Design Patterns. Introduction Promote reuse. Use the experiences of software developers. A shared library/lingo used by developers.
9/28/01F-1 © 2001 T. Horton CS 494 Object-Oriented Analysis & Design Design Patterns.
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 6: Using Design Patterns 1.
CSC 211 Introduction to Design Patterns. Intro to the course Syllabus About the textbook – Read the introduction and Chapter 1 Good attendance is the.
Design Patterns in Java Chapter 1 Introduction Summary prepared by Kirk Scott 1.
CS2110: SW Development Methods Inheritance in OO and in Java Part 1: Introduction Readings: A few pages in Ch. 2 of MSD text introduce this Section 3.3.
Patterns and Reuse. Patterns Reuse of Analysis and Design.
GRASP: Designing Objects with Responsibilities
1 © 2007 T. Horton CS 441, Summer 2007 Principles of SW Design Design Patterns in Context – Doing design: can we say more about how to go about it? Readings:
GoF Sections Design Problems and Design Patterns.
18 April 2005CSci 210 Spring Design Patterns 1 CSci 210.
Design Patterns CS 124 Reference: Gamma et al (“Gang-of-4”), Design Patterns.
ECE450S – Software Engineering II
Introduction to Design Patterns Part 1. © Lethbridge/Laganière 2001 Chapter 6: Using design patterns2 Patterns - Architectural Architectural Patterns:
CS2110: SW Development Methods Inheritance in OO and in Java Part 2: Topics: Forms of inheritance Interfaces in Java.
Copyright © Active Frameworks Inc. - All Rights Reserved - V2.0Design Pattern Catalog - Page L3-1 PS95&96-MEF-L10-1 Dr. M.E. Fayad Creationa.
CS616: Software Engineering Spring 2009 Design Patterns Sami Taha.
Software Design Patterns Curtsy: Fahad Hassan (TxLabs)
Advanced Object-Oriented Design Patterns and Architectures Part One COEN396A John Xiao
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 6: Using Design Patterns.
Design Patterns Software Engineering CS 561. Last Time Introduced design patterns Abstraction-Occurrence General Hierarchy Player-Role.
More Design Patterns From: Shalloway & Trott, Design Patterns Explained, 2 nd ed.
Design Patterns Introduction
1 Chapter 5:Design Patterns. 2 What are design pattern?  Schematic description of design solution to recurring problems in software design and,  Reusable.
Adapter and Façade Patterns By Wode Ni and Leonard Bacon-Shone.
The Factory Method Pattern (Creational) ©SoftMoore ConsultingSlide 1.
The Strategy Pattern (Behavioral) ©SoftMoore ConsultingSlide 1.
Example to motivate discussion We have two lists (of menu items) one implemented using ArrayList and another using Arrays. How does one work with these.
Watching the movie the hard way…. Page 256 – Head First Design Patterns.
CS 210 Proxy Pattern Nov 16 th, RMI – A quick review A simple, easy to understand tutorial is located here:
1/15/03A-1 © 2001 T. Horton CS 494 Object-Oriented Analysis & Design Course Introduction Dr. Tom Horton Phone: Office.
1/20/05A-1 © 2001 T. Horton CS 494 Adv. SW Design and Development A Tasting…. Course 1: Design patterns: Intro, example Course 2: Inheritance, Interfaces,
Duke CPS Programming Heuristics l Identify the aspects of your application that vary and separate them from what stays the same ä Take what varies.
CLASSIFICATION OF DESIGN PATTERNS Hladchuk Maksym.
Design Patterns CSCE 315 – Programming Studio Spring 2013.
1 Lecture Material Design Patterns Visitor Client-Server Factory Singleton.
Presented by FACADE PATTERN
GRASP – Designing Objects with Responsibilities
Design Patterns: MORE Examples
Design Patterns: Brief Examples
Chapter 5:Design Patterns
Software Design Patterns
MPCS – Advanced java Programming
Design Patterns Lecture part 2.
Introduction to Design Patterns
Introduction to Design Patterns Part 1
Informatics 122 Software Design II
Introduction to Design Patterns
Informatics 122 Software Design II
Presentation transcript:

CS 4240: Introduction to Design Patterns Readings: Chap. 5 of Design Patterns Explained Also, Chap. 6 and 7 Also, on-line info on Composite pattern (and others) at

Readings Chapter 5 of our textbook Handouts on various patterns

Background, Definition From Alexander’s work in architecture Alexander: “a solution to a problem in context.” Design pattern: a description of a problem that reoccurs and an outline of an approach to solving that problem Generally domain, language independent Also, analysis patterns

Design Patterns: Essential Elements Pattern name A vocabulary of patterns is beneficial Intent Problem When to apply the pattern, what context. How to represent, organize components Conditions to be met before using Solution Design elements: relationships, responsibilities, collaborations A template for a solution that you implement Consequences Results and trade-offs that result from using the pattern Needed to evaluate design alternatives

Essential Elements (con’td) Participants and collaborators Implementation Generic Structure

Patterns Are (and Aren’t) Name and description of a proven solution to a problem Documentation of a design decision They’re not: Reusable code, class libraries, etc. (At a higher level) Do not require complex implementations Always the best solution to a given situation Simply “a good thing to do”

Describing Design Patterns The GoF defined a standard format Generally followed Not just a UML diagram! Pattern Format (13 sections): Pattern name and classification Intent: what’s it do? Rationale? Also known as Motivation A scenario that illustrates a sample problem and how this patterns helps solve it. Applicability For which situations can this be applied? Structure Graphical representation (e.g. UML)

Pattern Format (cont’d) Participants Classes and objects, their responsibilities Collaborations How participants interact Consequences Implementation Pitfalls, hints, techniques, language issues Sample code Code fragments that illustrate the pattern Known uses From real systems Related patterns Similar patterns, collaborating patterns

Example 1: Singleton Pattern Global variables are bad! Why? We often want to use global variables! Why?

Example 1: Singleton Pattern Context: Only one instance of a class is created. Everything in the system that needs this class interacts with that one object. Controlling access: Make this instance accessible to all clients Solution: The class has a static variable called theInstance (etc) The constructor is made private (or protected) Clients call a public operation getInstance() that returns the one instance This may construct the instance the very first time or be given an initializer

Singleton: Java implementation public class MySingleton { private static MySingleton theInstance = new MySingleton(); private MySingleton() { // constructor … } public static MySingleton getInstance() { return theInstance; } }

Static Factory Methods Singleton patterns uses a static factory method Factory: something that creates an instance Advantages over a public constructor They have names. Example: BigInteger(int, int, random) vs. BigInteger.probablePrime() Might need more than one constructor with same/similar signatures Can return objects of a subtype (if needed) Wrapper class example: Double d1 = Double.valueOf(“3.14”); Double d2 = new Double (“3.14”); More info: Bloch’s Effective Java

Examples from Java Library In Swing, you can create a Border and add it to a component Border b = BorderFactory.createBevelBorder(3); Need the exact same border again? The above method doesn’t create a new one. Just gives you the same one Note: works because the bevel is immutable

Example from the Java Library Java can manipulate its own class definitions Example: Class classObj = Class.forName(“edu.uva.cs441.MyClass”); Then we can do things to the Class object What if we call this again? Only one Class object per Java-class

Example #2: PlayLists and Songs We saw this in CS201 (maybe)

Could PlayLists “Nest”? Could a PlayList contain Songs and other PlayLists? This is the “Composite Design Pattern” Make PlayList contain A list of PlayableItems, not Songs PlayList.play() calls play() on each item Polymorphism at work

Class Diagram for This Composite

General Class Diagram Could be many Leaf classes

Polymorphism in Action Playlist contains a list of PlayableItems PlayList.play() calls play() on each item for (int i=0; i<list.size(); ++i) { ( (PlayableItem) list.get(i) ).play(); } Will call the Song.play() or PlayList.play() depending on what item i really is Review question: why is the cast needed?

Façade Pattern Intent: Simplify interface to set of interfaces in an existing subsystem. Or, need to define new/variant interface Problem: Only need part of a complex system. Or, need to interact in a particular way. Participants, collaborators: Façade class, subsystem classes, client class

Façade Pattern (cont’d) Consequences: Certain subsystem operations may not be available in the façade Clients may “go around” the facade

Note in textbook Reduce coupling for client Existing interfaces requires client to access many objects to carry out task Façade object may be one object that’s a “gateway” to multiple objects In other words: the Façade encapsulates the system Another motto: find what varies and encapsulate it

Examples: Java’s URL class Really hides a set of objects and methods But not easy to see that it does this IMHO An example from our recent CS1110 textbook Make I/O easier for beginners Class StdIn: static methods to read Class In: create object to read from keyboard, file or URL

Class In from Princeton course text See Javadoc here:

Encapsulate Scanner, simplify methods public final class In { private Scanner scanner;... public In() { scanner = new Scanner( new BufferedInputStream(System.in), charsetName); scanner.useLocale(usLocale); }... /** * Is the input stream empty? */ public boolean isEmpty() { return !scanner.hasNext(); }

Create “reader” from filename or URL public In(String s) { try { // first try to read file from local file system File file = new File(s); if (file.exists()) { scanner = new Scanner(file, charsetName); scanner.useLocale(usLocale); return; } // next try for files included in jar URL url = getClass().getResource(s); // or URL from web if (url == null) { url = new URL(s); } URLConnection site = url.openConnection(); InputStream is = site.getInputStream(); scanner = new Scanner( new BufferedInputStream(is), charsetName); scanner.useLocale(usLocale); } catch (IOException ioe) { System.err.println("Could not open " + s); }

Think About and Discuss Façade: any relation to the Law of Demeter? “Principle of Least Knowledge” Talk only your immediate friends

Adaptor Pattern Intent: Make an existing object match an existing interface that it doesn’t match Problem: Existing component has right functionality but doesn’t match the interface used Interface here? Abstract class (or Java-interface) used polymorphically Solution: Wrapper class with delegation etc. Two flavors: Object Adaptor vs. Class Adaptor

Adaptor Pattern (cont’d) Participants and Collaborators Adapter class: “new” interface for… Adaptee class (existing class) Target: the needed interface Client who uses objects of type Target Consequences: The good: solves problem and meets intent above! Some other wrinkles…

Class Diagram for Object Adaptor Object Adaptor pattern Note that Adapter is an example of a “wrapper class” A common implementation technique used in several design patterns

Book’s Example Abstract class (or interface) Shape Methods include: display(), fill() Our code relies on Shape hierarchy and polymorphism We need a Circle class Sweet! Another one exists! XXCircle Bummer! Method names are different Solution: see book or notes on board

Class Adaptor Pattern Don’t create a separate object that wraps the existing object Instead, create new class that Includes what existing class has (inherit) Also meets Target interface With a Java interface, or multiple inheritance in other languages

Class Adaptor example Problem: Existing code has a CommandBuffer class Doesn’t have an Iterator You have code that could do great things if only you could use CommandBuffer as if it were Iterable

Example of Class Adaptor pattern The new class implements Iterator methods in terms of getCommand() etc defined in existing class No pair of objects: just an instance of new class

Think About and Discuss Class adaptors are different than object adaptors Does this difference relate to a “rule” or “principle” of OO design we’ve seen?

Comparing Façade and Adaptor Similarities: Both designed to help us use existing classes better Both can use wrapper objects Similar implementation solves different problems Adaptor: existing interface we must design to (not for Façade) New object used polymorphically Façade: need simpler interface (not a goal for Adaptor) See table 7-1 on page 110

Summary of Intro to Design Patterns Understand background, general principles of design patterns Examples: Singleton Composite Façade Adaptor Recognize them, apply them in simple situations

Exercise: Can you Adapt? Deprecated Java interface Enumerator hasMoreElements() nextElement() Replaced by interface Iterator hasNext() next() remove()

Your task Create a class: EnumerationIterator This let us design and write new code that works with Iterators, and also interact with legacy code that exposes Enumerators for use to use First question: class or object adaptor?

Questions to Answer Question: which classes play which roles in the design pattern? Write this down. Final question: write Java class with constructor and next() and hasNext().