Traditional Design Patterns -- II
|
|
- Patrick Valentine Boone
- 5 years ago
- Views:
Transcription
1 Traditional Design Patterns -- II These slides are mainly based on: Tutorial slides by John Vlissides, see and Text by Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides Diagrams 1995 by Addison-Wesley Publishing Company Note: Compared to the original tutorial by John Vlissides, the diagram notation have been upgraded from OMT to UML and some text has been updated 1
2 Overview Example: WYSIWYG Editor (Cont'd) Spelling checking & hyphenation Iterator Visitor Some more patterns Template Method Singleton Façade Observations and Conclusions Further reading 2
3 Spelling Checking and Hyphenation E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Goals: Analyze text for spelling errors Introduce potential hyphenation sites Constraints: Support multiple algorithms Don't mix up with document structure 3
4 Solution: Encapsulate traversal E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Iterator Encapsulates a traversal algorithm Uses Glyph's child enumeration operation 4
5 Iterator (Behavioral) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Intent Access elements of an aggregate sequentially without exposing its representation Applicability Require multiple traversal algorithms over an aggregate Require a uniform traversal interface over different aggregates When aggregate classes and traversal algorithm must vary independently 5
6 Iterator (cont'd) Structure E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley 6
7 Iterator Examle import java.util.*; class IntSet { private Hashtable ht = new Hashtable(); public static class Iterator { private IntSet set; private Enumeration e; private Integer current; public Iterator( IntSet in ) { set = in; } public void first() { e = set.ht.keys(); next(); } public boolean isdone() { return current == null; } public int currentitem() { return current.intvalue(); } public void next() { try { current = (Integer) e.nextelement(); } catch (NoSuchElementException e) { current = null; } } } public void add( int in ) { ht.put( new Integer( in ), "null" ); } public boolean ismember( int i ) { return ht.containskey(new Integer(i)); } public Hashtable gethashtable() { return ht; } public Iterator createiterator() { return new Iterator( this ); } } 7
8 Iterator Example class IteratorDemo { public static void main( String[] args ) { IntSet set = new IntSet();. // Code to add elements to the set and other code } } // Clients ask the collection object to create many iterator objects IntSet.Iterator it1 = set.createiterator(); IntSet.Iterator it2 = set.createiterator(); // Clients use the first(), isdone(), next(), currentitem() protocol System.out.print( "\niterator: " ); for ( it1.first(), it2.first();! it1.isdone(); it1.next(), it2.next() ) System.out.print( it1.currentitem() + " " + it2.currentitem() + " " ); System.out.print( "\nenumeration: " ); for (Enumeration e = set.gethashtable().keys(); e.hasmoreelements(); ) System.out.print( e.nextelement() + " " ); System.out.println(); 8
9 Iterator (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Consequences + Flexibility: aggregate and traversal are independent + Multiple iterators multiple traversal algorithms Additional communication overhead between iterator and aggregate Implementation Internal versus external iterators Violating the object structure's encapsulation Robust iterators Known Uses Penpoint traversal driver/slave InterViews ListItr Unidraw Iterator 9
10 Overview Example: WYSIWYG Editor (Cont'd) Spelling checking & hyphenation Iterator Visitor Some more patterns Template Method Singleton Façade Observations and Conclusions Further reading 10
11 Spelling Checking and Hyphenation (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Visitor Defines action(s) at each step of traversal Avoids wiring action(s) into Glyphs Iterator calls glyph's accept(visitor) at each node accept calls back on visitor void Character.accept (Visitor v) { v.visit(this); } interface Visitor { void visit(character); void visit(rectangle); void visit(row); // etc. for all relevant Glyph subclasses } 11
12 Spelling Checking and Hyphenation (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley SpellingCheckerVisitor Gets character code from each character glyph Can define getcharcode operation just on Character class Checks words accumulated from character glyphs Combine with PreorderIterator 12
13 Spelling Checking and Hyphenation Accumulating Words (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Spelling check on each non-alphabetic character 13
14 Interaction Diagram E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley 14
15 Spelling Checking and Hyphenation (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley HyphenationVisitor Gets character code from each character glyph Examines words accumulated from character glyphs At potential hyphenation point, inserts a... 15
16 Spelling Checking and Hyphenation (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Discretionary glyph Looks like a hyphen when it falls at the end of a line Has no appearance otherwise Compositor considers its presence when determining linebreaks 16
17 Visitor (Behavioral) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Intent Centralize operations on an object structure so that they can vary independently but still behave polymorphically Applicability When classes define many unrelated operations Class relationships of objects in the structure rarely change, but the operations on them change often Algorithms over the structure maintain state that's updated during traversal 17
18 Visitor (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Consequences + Flexibility: visitor and object structure are independent + Localized functionality Circular dependency between Visitor and Element interfaces Visitor brittle to new ConcreteElement classes Implementation Double dispatch Overloading visit operations Catch-all operation General interface to elements of object structure Known Uses ProgramNodeEnumerator in Smalltalk-80 compiler IRIS Inventor scene rendering 18
19 Visitor (cont'd) Structure E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley 19
20 Example A Printing Visitor public class SomeContainer implements Container { public void accept (Visitor visitor) { } for each Object i in this container{ visitor.visit (i); if (visitor.isdone(this)) break; } } //... public class PrintingVisitor extends AbstractVisitor { public void visit (Object object) { System.out.println (object); } //... } // // in another class... Container c = new SomeContainer (); //... c.accept (new PrintingVisitor ()); Definition of SomeContainer and of the accept method Use of visitor 20
21 Editor Example Summary Document Structure Composite Formatting Strategy Embellishment Decorator Multiple Look&Feels Abstract Factory (Multiple window systems) Bridge (User operations) Command Spelling checking & hyphenation Iterator & Visitor 21
22 Overview Example: WYSIWYG Editor (Cont'd) Spelling checking & hyphenation Iterator Visitor Some more patterns Template Method Singleton Façade Observations and Conclusions Further reading 22
23 Template Method (Behavioral) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Intent Define the skeleton of an algorithm in an operation, deferring some steps to subclasses Applicability To implement invariant aspects of an algorithm once and let subclasses define variant parts To localize common behavior in a class to increase code reuse To control subclass extensions 23
24 Template Method (cont'd) Structure E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley 24
25 Template Method (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Consequences + Leads to inversion of control ( Hollywood principle : don't call us we'll call you) + Promotes code reuse + Lets you enforce overriding rules Must subclass to specialize behavior Implementation Virtual vs. non-virtual template method Few vs. lots of primitive operations Naming conventions (do- prefix) Known Uses Just about all object-oriented systems (especially frameworks) 25
26 Template Method (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Typical implementation: public abstract class Node { public final void streamout (OutputStream out) { if (isreadable()) { dostreamout(out); } else { dowarning(unreadablewarning); } } //... isreadable, dostreamout, and dowarning are primitive operations 26
27 Template Method - Example 27
28 Template Method - Example class Account { public: void Transaction(float amount); void virtual TransactionSubpartA(); void virtual TransactionSubpartB(); void virtual TransactionSubpartC(); } void Account::Transaction(float amount) { TransactionSubpartA(); TransactionSubpartB(); TransactionSubpartC(); // EvenMoreCode; } class JuniorAccount : public Account { public: void virtual TransactionSubpartA(); } class SavingsAccount : public Account { public: void virtual TransactionSubpartC(); } // Client code Account* customer; customer = JunionAccount(); customer->transaction(amount); 28
29 Singleton (Creational) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Intent Ensure a class only ever has one instance, and provide a global point of access to it. Applicability When there must be exactly one instance of a class, and it must be accessible from a well-known access point When the sole instance should be extensible by subclassing, and clients should be able to use an extended instance without modifying their code 29
30 Singleton (cont'd) Structure E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley 30
31 Singleton (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Consequences + Reduces namespace pollution + Makes it easy to change your mind and allow more than one instance + Allow extension by subclassing Same drawbacks of a global if misused Implementation may be less efficient than a global Concurrency pitfalls Implementation Static instance operation Registering the singleton instance 31
32 Singleton (cont'd) E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Known Uses Unidraw's Unidraw object Smalltalk-80 ChangeSet, the set of changes to code InterViews Session object 32
33 Singleton - Example class Singleton { public: }; static Singleton* Instance(); protected: Singleton(); Singleton(const Singleton&); Singleton& operator= (const Singleton&) private: static Singleton* pinstance; Singleton* Singleton::pinstance = 0; // initialize pointer Singleton* Singleton::Instance () { if (pinstance == 0) // is it the first call? { pinstance = new Singleton; // create sole instance } return pinstance; // address of sole instance } Singleton::Singleton() { //... perform necessary instance initializations } 33
34 Singleton - Example // Client code Singleton *p1 = Singleton::Instance(); Singleton *p2 = p1->instance(); Singleton & ref = * Singleton::Instance(); Although the above example uses a single instance, modifications to the function Instance() may permit a variable number of instances. For example, you can design a class that allows up to three instances. 34
35 Overview Example: WYSIWYG Editor (Cont'd) Spelling checking & hyphenation Iterator Visitor Some more patterns Template Method Singleton Façade Observations and Conclusions Further reading 35
36 Façade E. Gamma, R. Helm, R. Johnson, J. Vlissides and Addison-Wesley Façade 36
37 Façade 37
38 Façade - Example 38
39 Overview Example: WYSIWYG Editor (Cont'd) Spelling checking & hyphenation Iterator Visitor Some more patterns Template Method Singleton Façade Observations and Conclusions Further reading 39
40 Inheritance vs. Object Composition Object composition + Provides for clean separation between components through interfaces + Allows for dynamic composition + Allows for flexible mixing and matching of features Has the overhead of forwarding Suffers from the identity crisis Leads to more fragmentation Inheritance + No explicit forwarding necessary Close coupling between a class and its base class Inheritance hierarchies are static and cannot be reconfigured at runtime Adding features through subclassing may lead to a combinatorial explosion Beware of overusing inheritance inheritance is not always the best choice Deep inheritance hierarchy (6 levels and more) in your application is a red flag 40
41 Implementation vs. interface inheritance Implementation inheritance inheriting implementation of methods Is a convenient reuse mechanism, but Introduces high coupling Changing a superclass may brake all subclasses ( fragile base class problem ) Interface inheritance inheriting interface but no implementation (e.g., inheritance involving abstract classes in C++ and interfaces in Java) Does not suffer from the problems of implementation inheritance Subtyping and interface inheritance are more important than implementation inheritance Consider declaring the type of variables to be interfaces rather than concrete classes 41
42 OO Frameworks A framework consists of a set of cooperating classes embodying a design for a family of applications. There are different categories of frameworks: White-box frameworks are reused by subclassing, which usually requires understanding the implementation of the framework to some degree Template method is one of the main mechanisms for white-box frameworks Black-box framework is reused by parameterizing and assembling framework objects. Black-box frameworks hide their implementation from their users Black-box frameworks make heavy use of patterns based on object composition such as decorator and strategy. Many practical frameworks fall somewhere between the white-box and black-box categories 42
43 Patterns at Different Levels Applicable in most stages of the OO lifecycle Analysis, design, implementation, reviews, documentation, reuse, and refactoring Analysis patterns Typical solutions to recuring anlysis problems See Analysis Patterns, Fowler; Addison-Wesley, 1996 Architectural patterns See POSA Design patterns Most GoF design patterns are applicable both at the architectural and detailed design Idioms Smalltalk Best Practice Patterns, Beck; Prentice Hall, 1997 Concurrent Programming in Java, Lea; Addison-Wesley, 1997 Advanced C++, Coplien, Addison-Wesley, 1992 Effective C++: 50 Specific Ways to Improve Your Programs and Design (2nd Edition), Scott Meyers, Addison-Wesley, (September 1997) More Effective C++: 35 New Ways to Improve Your Programs and Designs, Scott Meyers, Addison-Wesley (December 1995) 43
44 Observations Patterns permit design at a more abstract level Treat many class/object interactions as a unit Often beneficial after initial design Targets for class refactorings Variation-oriented design Consider what design aspects are variable Identify applicable pattern(s) Vary patterns to evaluate tradeoffs Repeat 44
45 But... Resist branding everything a pattern Articulate specific benefits Demonstrate wide applicability Find at least two existing examples Don't apply them blindly Added indirection increased complexity, cost Pattern design even harder than OOD! 45
46 Overall Notes Design patterns promote Design reuse Uniform design vocabulary Understanding, restructuring Automation A new way of thinking about design 46
47 Overview Example: WYSIWYG Editor (Cont'd) Spelling checking & hyphenation Iterator Visitor Some more patterns Template Method Singleton Façade Observations and Conclusions Further reading 47
48 (Design) Pattern References The Timeless Way of Building, Alexander; Oxford, 1979; ISBN A Pattern Language, Alexander; Oxford, 1977; ISBN Design Patterns, Gamma, et al.; Addison-Wesley, 1995; ISBN ; CD version ISBN Pattern-Oriented Software Architecture, Buschmann, et al.; Wiley, 1996; ISBN Analysis Patterns, Fowler; Addison-Wesley, 1996; ISBN Smalltalk Best Practice Patterns, Beck; Prentice Hall, 1997; ISBN X The Design Patterns Smalltalk Companion, Alpert, et al.; Addison- Wesley, 1998; ISBN AntiPatterns, Brown, et al.; Wiley, 1998; ISBN
49 More Books Pattern Languages of Program Design (Addison-Wesley) Vol. 1, Coplien, et al., eds.; 1995; ISBN Vol. 2, Vlissides, et al., eds.; 1996; ISBN Vol. 3, Martin, et al., eds.; 1998; ISBN Vol. 4, Harrison, et al., eds.; 2000; ISBN Concurrent Programming in Java, Lea; Addison-Wesley, 1997; ISBN Applying UML and Patterns, Larman; 2 nd edition, Prentice Hall, 2002; ISBN Pattern Hatching: Design Patterns Applied, Vlissides; Addison- Wesley, 1998; ISBN The Pattern Almanac, Rising; Addison-Wesley, 2000; ISBN
50 More Books Advanced C++, Coplien, Addison-Wesley, 1992 Effective C++: 50 Specific Ways to Improve Your Programs and Design (2nd Edition), Scott Meyers, Addison-Wesley, (September 1997) More Effective C++: 35 New Ways to Improve Your Programs and Designs, Scott Meyers, Addison-Wesley (December 1995) 50
51 Early Papers Object-Oriented Patterns, P. Coad; Comm. of the ACM, 9/92 Documenting Frameworks using Patterns, R. Johnson; OOPSLA '92 Design Patterns: Abstraction and Reuse of Object-Oriented Design, Gamma, Helm, Johnson, Vlissides, ECOOP '93. Columns: C++ Report, Dr. Dobbs Sourcebook, JOOP, ROAD 51
52 Conferences PLoP: Pattern Languages of Programs, Monticello, Illinois, USA (September) EuroPLoP, Kloster Irsee, Germany (July) ChiliPLoP 2000, March 2000, Wickenburg, Arizona, USA KoalaPLoP 2000, May 2000, Melbourne, Australia See for upto-the-minute information. 52
53 Mailing Lists present and refine patterns general discussion on patterns discussion on Design Patterns discussion on Pattern-Oriented Software Architecture discussion on user interface design patterns discussion on patterns for business processes discussion on patterns for distributed systems See for an up-to-date list. 53
54 URLs General Conferences Books Mailing Lists Portland Patterns Repository 54
SURESH BABU M ASST PROFESSOR VJIT UNIT-II
SURESH BABU M ASST PROFESSOR VJIT L1 seven problems in Lexis's design: Document Structure: The choice of internal representation for the document affects nearly every aspect of Lexis's design. All editing,
More informationDesign Patterns. Gunnar Gotshalks A4-1
Design Patterns A4-1 On Design Patterns A design pattern systematically names, explains and evaluates an important and recurring design problem and its solution Good designers know not to solve every problem
More informationCS560. Lecture: Design Patterns II Includes slides by E. Gamma et al., 1995
CS560 Lecture: Design Patterns II Includes slides by E. Gamma et al., 1995 Classification of GoF Design Pattern Creational Structural Behavioural Factory Method Adapter Interpreter Abstract Factory Bridge
More informationCSCI 253. Overview. The Elements of a Design Pattern. George Blankenship 1. Object Oriented Design: Template Method Pattern. George Blankenship
CSCI 253 Object Oriented Design: George Blankenship George Blankenship 1 Creational Patterns Singleton Abstract factory Factory Method Prototype Builder Overview Structural Patterns Composite Façade Proxy
More informationAn Introduction to Patterns
An Introduction to Patterns Robert B. France Colorado State University Robert B. France 1 What is a Pattern? - 1 Work on software development patterns stemmed from work on patterns from building architecture
More informationIdioms and Design Patterns. Martin Skogevall IDE, Mälardalen University
Idioms and Design Patterns Martin Skogevall IDE, Mälardalen University 2005-04-07 Acronyms Object Oriented Analysis and Design (OOAD) Object Oriented Programming (OOD Software Design Patterns (SDP) Gang
More informationPatterns. Erich Gamma Richard Helm Ralph Johnson John Vlissides
Patterns Patterns Pattern-based engineering: in the field of (building) architecting and other disciplines from 1960 s Some software engineers also started to use the concepts Become widely known in SE
More informationGoals of Lecture. Lecture 27: OO Design Patterns. Pattern Resources. Design Patterns. Cover OO Design Patterns. Pattern Languages of Programming
Goals of Lecture Lecture 27: OO Design Patterns Cover OO Design Patterns Background Examples Kenneth M. Anderson Object-Oriented Analysis and Design CSCI 6448 - Spring Semester, 2001 April 24, 2001 Kenneth
More informationLecture 13: Design Patterns
1 Lecture 13: Design Patterns Kenneth M. Anderson Object-Oriented Analysis and Design CSCI 6448 - Spring Semester, 2005 2 Pattern Resources Pattern Languages of Programming Technical conference on Patterns
More informationPattern Resources. Lecture 25: Design Patterns. What are Patterns? Design Patterns. Pattern Languages of Programming. The Portland Pattern Repository
Pattern Resources Lecture 25: Design Patterns Kenneth M. Anderson Object-Oriented Analysis and Design CSCI 6448 - Spring Semester, 2003 Pattern Languages of Programming Technical conference on Patterns
More informationDesign Patterns. An introduction
Design Patterns An introduction Introduction Designing object-oriented software is hard, and designing reusable object-oriented software is even harder. Your design should be specific to the problem at
More informationSOFTWARE PATTERNS. Joseph Bonello
SOFTWARE PATTERNS Joseph Bonello MOTIVATION Building software using new frameworks is more complex And expensive There are many methodologies and frameworks to help developers build enterprise application
More informationAn Introduction to Patterns
An Introduction to Patterns Robert B. France Colorado State University Robert B. France 1 What is a Pattern? Patterns are intended to capture the best available software development experiences in the
More informationMore on Design. CSCI 5828: Foundations of Software Engineering Lecture 23 Kenneth M. Anderson
More on Design CSCI 5828: Foundations of Software Engineering Lecture 23 Kenneth M. Anderson Outline Additional Design-Related Topics Design Patterns Singleton Strategy Model View Controller Design by
More informationSoftware Design Patterns. Background 1. Background 2. Jonathan I. Maletic, Ph.D.
Software Design Patterns Jonathan I. Maletic, Ph.D. Department of Computer Science Kent State University J. Maletic 1 Background 1 Search for recurring successful designs emergent designs from practice
More informationThink of drawing/diagramming editors. ECE450 Software Engineering II. The problem. The Composite pattern
Think of drawing/diagramming editors ECE450 Software Engineering II Drawing/diagramming editors let users build complex diagrams out of simple components The user can group components to form larger components......which
More informationCSCD01 Engineering Large Software Systems. Design Patterns. Joe Bettridge. Winter With thanks to Anya Tafliovich
CSCD01 Engineering Large Software Systems Design Patterns Joe Bettridge Winter 2018 With thanks to Anya Tafliovich Design Patterns Design patterns take the problems consistently found in software, and
More informationSDC Design patterns GoF
SDC Design patterns GoF Design Patterns The design pattern concept can be viewed as an abstraction of imitating useful parts of other software products. The design pattern is a description of communicating
More informationTopics in Object-Oriented Design Patterns
Software design Topics in Object-Oriented Design Patterns Material mainly from the book Design Patterns by Erich Gamma, Richard Helm, Ralph Johnson and John Vlissides; slides originally by Spiros Mancoridis;
More informationCoordination Patterns
Coordination Patterns 1. Coordination Patterns Design Patterns and their relevance for Coordination Oscar Nierstrasz Software Composition Group Institut für Informatik (IAM) Universität Bern oscar@iam.unibe.ch
More informationCSCD01 Engineering Large Software Systems. Design Patterns. Joe Bettridge. Winter With thanks to Anya Tafliovich
CSCD01 Engineering Large Software Systems Design Patterns Joe Bettridge Winter 2018 With thanks to Anya Tafliovich Design Patterns Design patterns take the problems consistently found in software, and
More informationOe Overview. Overview (cont d) Part I: Motivation & Concept. Douglas C. Schmidt Vanderbilt University Part II: Application
An Introduction ti to Design Patterns Douglas C. Schmidt Vanderbilt University schmidt@dre.vanderbilt.edu Oe Overview Part I: Motivation & Concept the issue what design patterns are what they re good for
More informationObject-Oriented Design
Object-Oriented Design Lecture 20 GoF Design Patterns Behavioral Department of Computer Engineering Sharif University of Technology 1 GoF Behavioral Patterns Class Class Interpreter: Given a language,
More informationObject-Oriented Design
Object-Oriented Design Lecturer: Raman Ramsin Lecture 20: GoF Design Patterns Creational 1 Software Patterns Software Patterns support reuse of software architecture and design. Patterns capture the static
More informationDesign patterns. Valentina Presutti courtesy of Paolo Ciancarini
Design patterns Valentina Presutti courtesy of Paolo Ciancarini Agenda What are design patterns? Catalogues of patterns Languages of patterns Two case studies: design with patterns Software Architectures
More informationDesign Pattern and Software Architecture: IV. Design Pattern
Design Pattern and Software Architecture: IV. Design Pattern AG Softwaretechnik Raum E 3.165 Tele.. 60-3321 hg@upb.de IV. Design Pattern IV.1 Introduction IV.2 Example: WYSIWYG Editor Lexi IV.3 Creational
More informationUsing Design Patterns in Java Application Development
Using Design Patterns in Java Application Development ExxonMobil Research & Engineering Co. Clinton, New Jersey Michael P. Redlich (908) 730-3416 michael.p.redlich@exxonmobil.com About Myself Degree B.S.
More informationFoundations of Software Engineering Design Patterns -- Introduction
Foundations of Software Engineering Design Patterns -- Introduction Fall 2016 Department of Computer Science Ben-Gurion university Based on slides of: Nurit Gal-oz, Department of Computer Science Ben-Gurion
More informationSlide 1. Design Patterns. Prof. Mirco Tribastone, Ph.D
Slide 1 Design Patterns Prof. Mirco Tribastone, Ph.D. 22.11.2011 Introduction Slide 2 Basic Idea The same (well-established) schema can be reused as a solution to similar problems. Muster Abstraktion Anwendung
More informationDesign Patterns Reid Holmes
Material and some slide content from: - Head First Design Patterns Book - GoF Design Patterns Book Design Patterns Reid Holmes GoF design patterns $ %!!!! $ "! # & Pattern vocabulary Shared vocabulary
More informationThe GoF Design Patterns Reference
The GoF Design Patterns Reference Version.0 / 0.0.07 / Printed.0.07 Copyright 0-07 wsdesign. All rights reserved. The GoF Design Patterns Reference ii Table of Contents Preface... viii I. Introduction....
More informationIngegneria del Software Corso di Laurea in Informatica per il Management. Design Patterns part 1
Ingegneria del Software Corso di Laurea in Informatica per il Management Design Patterns part 1 Davide Rossi Dipartimento di Informatica Università di Bologna Pattern Each pattern describes a problem which
More informationKerievsky_book.fm Page 355 Thursday, July 8, :12 PM. Index
Kerievsky_book.fm Page 355 Thursday, July 8, 2004 12:12 PM Index A Absorbing class, 117 Abstract Factory, 70 71 Accept methods, 327 Accumulation methods, 315, 325 330 Accumulation refactorings Collecting
More informationInheritance. EEC 521: Software Engineering. Dealing with Change. Polymorphism. Software Design. Changing requirements Code needs to be flexible
Inheritance EEC 521: Software Engineering Software Design Design Patterns: Decoupling Dependencies 10/15/09 EEC 521: Software Engineering 1 Inheritance is the mechanism by which one class can acquire properties/responsibilities
More informationBehavioral Design Patterns Used in Data Structures Implementation
Behavioral Design Patterns Used in Data Structures Implementation Niculescu Virginia Department of Computer Science Babeş-Bolyai University, Cluj-Napoca email address: vniculescu@cs.ubbcluj.ro November,
More informationDesign Patterns. Hausi A. Müller University of Victoria. Software Architecture Course Spring 2000
Design Patterns Hausi A. Müller University of Victoria Software Architecture Course Spring 2000 1 Motivation Vehicle for reasoning about design or architecture at a higher level of abstraction (design
More informationObject-Oriented Design
Object-Oriented Design Lecture 14: Design Workflow Department of Computer Engineering Sharif University of Technology 1 UP iterations and workflow Workflows Requirements Analysis Phases Inception Elaboration
More informationDesign Patterns. Observations. Electrical Engineering Patterns. Mechanical Engineering Patterns
Introduction o to Patterns and Design Patterns Dept. of Computer Science Baylor University Some slides adapted from slides by R. France and B. Tekinerdogan Observations Engineering=Problem Solving Many
More informationbe used for more than one use case (for instance, for use cases Create User and Delete User, one can have one UserController, instead of two separate
UNIT 4 GRASP GRASP: Designing objects with responsibilities Creator Information expert Low Coupling Controller High Cohesion Designing for visibility - Applying GoF design patterns adapter, singleton,
More informationApplying Design Patterns to accelerate development of reusable, configurable and portable UVCs. Accellera Systems Initiative 1
Applying Design Patterns to accelerate development of reusable, configurable and portable UVCs. Accellera Systems Initiative 1 About the presenter Paul Kaunds Paul Kaunds is a Verification Consultant at
More informationPlan. Design principles: laughing in the face of change. What kind of change? What are we trying to achieve?
Plan Design principles: laughing in the face of change Perdita Stevens School of Informatics University of Edinburgh What are we trying to achieve? Review: Design principles you know from Inf2C-SE Going
More informationCHAPTER 6: CREATIONAL DESIGN PATTERNS
CHAPTER 6: CREATIONAL DESIGN PATTERNS SESSION III: BUILDER, PROTOTYPE, SINGLETON Software Engineering Design: Theory and Practice by Carlos E. Otero Slides copyright 2012 by Carlos E. Otero For non-profit
More informationAn Introduction to Patterns and Pattern Languages. Overview. Patterns -- Why? Patterns -- Why?
An Introduction to Patterns and Pattern Languages CSC591O April 7-9, 1997 Raleigh, NC Copyright (C) 1996, Kyle Brown, Bobby Woolf, and Knowledge Systems Corp. All rights reserved. 1 Kyle Brown Senior Member
More informationadministrivia today UML start design patterns Tuesday, September 28, 2010
administrivia Assignment 2? promise to get past assignment 1 back soon exam on monday review slides are posted your responsibility to review covers through last week today UML start design patterns 1 Unified
More informationDesign Patterns. Comp2110 Software Design. Department of Computer Science Australian National University. Second Semester
Design Patterns Comp2110 Software Design Department of Computer Science Australian National University Second Semester 2005 1 Design Pattern Space Creational patterns Deal with initializing and configuring
More informationFacade and Adapter. Comp-303 : Programming Techniques Lecture 19. Alexandre Denault Computer Science McGill University Winter 2004
Facade and Adapter Comp-303 : Programming Techniques Lecture 19 Alexandre Denault Computer Science McGill University Winter 2004 March 23, 2004 Lecture 19 Comp 303 : Facade and Adapter Page 1 Last lecture...
More informationbenefit familiarity understanding initiation consternation ignorance
Designing with Patterns John Vlissides T.J. Watson Research IBM vlis@watson.ibm.com 1996{1999 by John Vlissides. All rights reserved. c from Design Patterns: Elements of Reusable Object-Oriented Software
More informationCS/CE 2336 Computer Science II
CS/CE 2336 Computer Science II UT D Session 20 Design Patterns An Overview 2 History Architect Christopher Alexander coined the term "pattern" circa 1977-1979 Kent Beck and Ward Cunningham, OOPSLA'87 used
More informationWhat is Design Patterns?
Paweł Zajączkowski What is Design Patterns? 1. Design patterns may be said as a set of probable solutions for a particular problem which is tested to work best in certain situations. 2. In other words,
More informationDesign Pattern What is a Design Pattern? Design Pattern Elements. Almas Ansari Page 1
What is a Design Pattern? Each pattern Describes a problem which occurs over and over again in our environment,and then describes the core of the problem Novelists, playwrights and other writers rarely
More informationKeywords: Abstract Factory, Singleton, Factory Method, Prototype, Builder, Composite, Flyweight, Decorator.
Comparative Study In Utilization Of Creational And Structural Design Patterns In Solving Design Problems K.Wseem Abrar M.Tech., Student, Dept. of CSE, Amina Institute of Technology, Shamirpet, Hyderabad
More informationWork groups meeting 3
Work groups meeting 3 INF5040 (Open Distributed Systems) Sabita Maharjan sabita@simula.no Department of Informatics University of Oslo September 07, 2009 Design Patterns J2EE Design Patterns Outline EIS
More informationModellistica Medica. Maria Grazia Pia, INFN Genova. Scuola di Specializzazione in Fisica Sanitaria Genova Anno Accademico
Modellistica Medica Maria Grazia Pia INFN Genova Scuola di Specializzazione in Fisica Sanitaria Genova Anno Accademico 2002-2003 Lezione 8 OO modeling Design Patterns Introduction Creational Patterns Software
More informationObject Oriented Methods with UML. Introduction to Design Patterns- Lecture 8
Object Oriented Methods with UML Introduction to Design Patterns- Lecture 8 Topics(03/05/16) Design Patterns Design Pattern In software engineering, a design pattern is a general repeatable solution to
More informationSummary of the course lectures
Summary of the course lectures 1 Components and Interfaces Components: Compile-time: Packages, Classes, Methods, Run-time: Objects, Invocations, Interfaces: What the client needs to know: Syntactic and
More information3 Product Management Anti-Patterns by Thomas Schranz
3 Product Management Anti-Patterns by Thomas Schranz News Read above article, it s good and short! October 30, 2014 2 / 3 News Read above article, it s good and short! Grading: Added explanation about
More informationObject Oriented Paradigm
Object Oriented Paradigm Ming-Hwa Wang, Ph.D. Department of Computer Engineering Santa Clara University Object Oriented Paradigm/Programming (OOP) similar to Lego, which kids build new toys from assembling
More informationIngegneria del Software Corso di Laurea in Informatica per il Management. Design Patterns part 1
Ingegneria del Software Corso di Laurea in Informatica per il Management Design Patterns part 1 Davide Rossi Dipartimento di Informatica Università di Bologna Pattern Each pattern describes a problem which
More informationPATTERNS AND SOFTWARE DESIGN
This article first appeared in Dr. Dobb s Sourcebook, March/April, 1995. Copyright 1995, Dr. Dobb's Journal. PATTERNS AND SOFTWARE DESIGN Patterns for Reusable Object-Oriented Software Richard Helm and
More informationCS251 Software Engineering Lectures 18: Intro to DP
و ابتغ فيما آتاك هللا الدار اآلخرة و ال تنس نصيبك من الدنيا CS251 Software Engineering Lectures 18: Intro to DP Slides by Rick Mercer, Christian Ratliff, Oscar Nierstrasz and others 1 Outline Introduction
More informationLECTURE NOTES ON DESIGN PATTERNS MCA III YEAR, V SEMESTER (JNTUA-R09)
LECTURE NOTES ON DESIGN PATTERNS MCA III YEAR, V SEMESTER (JNTUA-R09) Mr. B KRISHNA MURTHI M.TECH, MISTE. Assistant Professor DEPARTMENT OF MASTER OF COMPUTER APPLICATIONS CHADALAWADA RAMANAMMA ENGINEERING
More informationApplying the Observer Design Pattern
Applying the Observer Design Pattern Trenton Computer Festival Professional Seminars Michael P. Redlich (908) 730-3416 michael.p.redlich@exxonmobil.com About Myself Degree B.S. in Computer Science Rutgers
More informationSoftware Reengineering Refactoring To Patterns. Martin Pinzger Delft University of Technology
Software Reengineering Refactoring To Patterns Martin Pinzger Delft University of Technology Outline Introduction Design Patterns Refactoring to Patterns Conclusions 2 The Reengineering Life-Cycle (1)
More informationSoftware Engineering - I An Introduction to Software Construction Techniques for Industrial Strength Software
Software Engineering - I An Introduction to Software Construction Techniques for Industrial Strength Software Chapter 9 Introduction to Design Patterns Copy Rights Virtual University of Pakistan 1 Design
More informationWhat is a Pattern? Lecture 40: Design Patterns. Elements of Design Patterns. What are design patterns?
What is a Pattern? Lecture 40: Design Patterns CS 62 Fall 2017 Kim Bruce & Alexandra Papoutsaki "Each pattern describes a problem which occurs over and over again in our environment, and then describes
More informationPattern Examples Behavioural
Pattern Examples Behavioural based on patterns in Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides, Design Patterns, Addison-Wesley, 1995. ISBN 0-201-63361-2 PE2-1 Iterator Pattern Intent» Access
More informationTrusted Components. Reuse, Contracts and Patterns. Prof. Dr. Bertrand Meyer Dr. Karine Arnout
1 Last update: 2 November 2004 Trusted Components Reuse, Contracts and Patterns Prof. Dr. Bertrand Meyer Dr. Karine Arnout 2 Lecture 5: Design patterns Agenda for today 3 Overview Benefits of patterns
More informationCrash course on design patterns
Crash course on design patterns Yann-Gaël Guéhéneuc guehene@emn.fr From Olivier Motelet s course (2001/10/17) École des Mines de Nantes, France Object Technology International, Inc., Canada Design patterns
More informationWhy a Design Pattern. History of Design Pattern. Properties
Introduction to Design Patterns Nasreddine Aoumeur Why a Design Pattern Reusability: one of the basis for an efficient and actual SE discipline Helping new designers to have a more flexible and reusable
More informationIdioms for Building Software Frameworks in AspectJ
Idioms for Building Software Frameworks in AspectJ Stefan Hanenberg 1 and Arno Schmidmeier 2 1 Institute for Computer Science University of Essen, 45117 Essen, Germany shanenbe@cs.uni-essen.de 2 AspectSoft,
More informationCPSC 310 Software Engineering. Lecture 11. Design Patterns
CPSC 310 Software Engineering Lecture 11 Design Patterns Learning Goals Understand what are design patterns, their benefits and their drawbacks For at least the following design patterns: Singleton, Observer,
More informationDESIGN PATTERN - INTERVIEW QUESTIONS
DESIGN PATTERN - INTERVIEW QUESTIONS http://www.tutorialspoint.com/design_pattern/design_pattern_interview_questions.htm Copyright tutorialspoint.com Dear readers, these Design Pattern Interview Questions
More informationThe following topics will be covered in this course (not necessarily in this order).
The following topics will be covered in this course (not necessarily in this order). Introduction The course focuses on systematic design of larger object-oriented programs. We will introduce the appropriate
More informationCSCI 253. Overview. The Elements of a Design Pattern. George Blankenship 1. Object Oriented Design: Iterator Pattern George Blankenship
CSCI 253 Object Oriented Design: Iterator Pattern George Blankenship George Blankenship 1 Creational Patterns Singleton Abstract factory Factory Method Prototype Builder Overview Structural Patterns Composite
More informationWork groups meeting 3
Work groups meeting 3 INF5040 (Open Distributed Systems) Amir Taherkordi amirhost@ifi.uio.no Department of Informatics University of Oslo September 18, 2008 Design Patterns J2EE Design Patterns AntiPatterns
More informationProduced by. Design Patterns. MSc in Communications Software. Eamonn de Leastar
Design Patterns MSc in Communications Software Produced by Eamonn de Leastar (edeleastar@wit.ie) Department of Computing, Maths & Physics Waterford Institute of Technology http://www.wit.ie http://elearning.wit.ie
More informationDesign Patterns. Manuel Mastrofini. Systems Engineering and Web Services. University of Rome Tor Vergata June 2011
Design Patterns Lecture 1 Manuel Mastrofini Systems Engineering and Web Services University of Rome Tor Vergata June 2011 Definition A pattern is a reusable solution to a commonly occurring problem within
More informationDesign patterns. OOD Lecture 6
Design patterns OOD Lecture 6 Next lecture Monday, Oct 1, at 1:15 pm, in 1311 Remember that the poster sessions are in two days Thursday, Sep 27 1:15 or 3:15 pm (check which with your TA) Room 2244 + 2245
More informationDesign Patterns. Claus Jensen
Design Patterns Claus Jensen What is a Design Pattern? A design pattern Abstracts a recurring design structure Distils design experience Promotes reuse of design and code Gives an opportunity to see how
More informationTackling Design Patterns Chapter 3: Template Method design pattern and Public Inheritance. 3.1 Introduction... 2
Department of Computer Science Tackling Design Patterns Chapter 3: Template Method design pattern and Public Inheritance Copyright c 2016 by Linda Marshall and Vreda Pieterse. All rights reserved. Contents
More informationCSE 70 Final Exam Fall 2009
Signature cs70f Name Student ID CSE 70 Final Exam Fall 2009 Page 1 (10 points) Page 2 (16 points) Page 3 (22 points) Page 4 (13 points) Page 5 (15 points) Page 6 (20 points) Page 7 (9 points) Page 8 (15
More informationPlan. Design principles: laughing in the face of change. What kind of change? What are we trying to achieve?
Plan Design principles: laughing in the face of change Perdita Stevens School of Informatics University of Edinburgh What are we trying to achieve? Review: Design principles you know from Inf2C-SE Going
More informationAdvanced Object Oriented PHP
CNM STEMulus Center Web Development with PHP November 11, 2015 1/17 Outline 1 2 Diamond Problem Composing vs Inheriting Case Study: Strategy Design Pattern 2/17 Definition is when a class is based on another
More informationL18.1 Introduction... 2
Department of Computer Science COS121 Lecture Notes: L18 Iterator Design Pattern 8 September 2014 Copyright c 2014 by Linda Marshall and Vreda Pieterse. All rights reserved. Contents L18.1 Introduction.................................
More informationCSE 401/M501 Compilers
CSE 401/M501 Compilers ASTs, Modularity, and the Visitor Pattern Hal Perkins Autumn 2018 UW CSE 401/M501 Autumn 2018 H-1 Agenda Today: AST operations: modularity and encapsulation Visitor pattern: basic
More information17. GRASP: Designing Objects with Responsibilities
17. GRASP: Designing Objects with Responsibilities Objectives Learn to apply five of the GRASP principles or patterns for OOD. Dr. Ziad Kobti School of Computer Science University of Windsor Understanding
More informationTuesday, October 4. Announcements
Tuesday, October 4 Announcements www.singularsource.net Donate to my short story contest UCI Delta Sigma Pi Accepts business and ICS students See Facebook page for details Slide 2 1 Design Patterns Design
More informationPatterns for polymorphic operations
Patterns for polymorphic operations Three small object structural patterns for dealing with polymorphism Alexander A. Horoshilov hor@epsylontech.com Abstract Polymorphism is one of the main elements of
More informationGénie Logiciel et Gestion de Projets. Patterns
Génie Logiciel et Gestion de Projets Patterns 1 Bit of history... Christoffer Alexander The Timeless Way of Building, Christoffer Alexander, Oxford University Press, 1979, ISBN 0195024028 Structure of
More informationThe Strategy Pattern Design Principle: Design Principle: Design Principle:
Strategy Pattern The Strategy Pattern defines a family of algorithms, encapsulates each one, and makes them interchangeable. Strategy lets the algorithm vary independently from clients that use it. Design
More informationCSCD01 Engineering Large Software Systems. Design Patterns. Joe Bettridge. Winter With thanks to Anya Tafliovich
CSCD01 Engineering Large Software Systems Design Patterns Joe Bettridge Winter 2018 With thanks to Anya Tafliovich Design Patterns Design patterns take the problems consistently found in software, and
More informationBCS Higher Education Qualifications. Diploma in IT. Object Oriented Programming Syllabus
BCS Higher Education Qualifications Diploma in IT Object Oriented Programming Syllabus Version 3.0 December 2016 This is a United Kingdom government regulated qualification which is administered and approved
More informationApplying the Decorator Design Pattern
Applying the Decorator Design Pattern Trenton Computer Festival Professional Seminars Michael P. Redlich (908) 730-3416 michael.p.redlich@exxonmobil.com About Myself Degree B.S. in Computer Science Rutgers
More informationDesign Patterns and Frameworks 1) Introduction
Design Patterns and Frameworks 1) Introduction Dr. Sebastian Götz Software Technology Group Department of Computer Science Technische Universität Dresden WS 16/17, Oct 11, 2016 Slides from Prof. Dr. U.
More informationAPPLYING DESIGN PATTERNS TO SCA IMPLEMENTATIONS
APPLYING DESIGN PATTERNS TO SCA IMPLEMENTATIONS Adem Zumbul (TUBITAK-UEKAE, Kocaeli, Turkey, ademz@uekae.tubitak.gov.tr); Tuna Tugcu (Bogazici University, Istanbul, Turkey, tugcu@boun.edu.tr) ABSTRACT
More informationEPL 603 TOPICS IN SOFTWARE ENGINEERING. Lab 6: Design Patterns
EPL 603 TOPICS IN SOFTWARE ENGINEERING Lab 6: Design Patterns Links to Design Pattern Material 1 http://www.oodesign.com/ http://www.vincehuston.org/dp/patterns_quiz.html Types of Design Patterns 2 Creational
More informationA Metric of the Relative Abstraction Level of Software Patterns
A Metric of the Relative Abstraction Level of Software Patterns Atsuto Kubo 1, Hironori Washizaki 2, and Yoshiaki Fukazawa 1 1 Department of Computer Science, Waseda University, 3-4-1 Okubo, Shinjuku-ku,
More informationWe hope that this paper will give you a good starting point on how to read, learn, find and use design patterns. After reading the whole example, you
Design Patterns, A Quick Introduction Thomas Panas, Vaxjo University Thomas.Panas@msi.vxu.se September 2001 1 Introduction Each pattern describes a problem which occurs over and over again in our environment,
More informationIntroduction and History
Pieter van den Hombergh Fontys Hogeschool voor Techniek en Logistiek September 15, 2016 Content /FHTenL September 15, 2016 2/28 The idea is quite old, although rather young in SE. Keep up a roof. /FHTenL
More informationIntroduction to Design Patterns
Dr. Michael Eichberg Software Engineering Department of Computer Science Technische Universität Darmstadt Software Engineering Introduction to Design Patterns (Design) Patterns A pattern describes... Patterns
More information