380 likes | 519 Views
SOEN 343 Software Design. Section H Fall 2006 Dr Greg Butler http://www.cs.concordia.ca/~gregb/home/soen343h-f06.html. Outline. GoF Design Patterns Adapter, Façade, Strategy, Observer Design Review. GoF Pattern Summary & Relationships. GoF Pattern Classification. Behavioral Patterns
E N D
SOEN 343Software Design Section H Fall 2006 Dr Greg Butler http://www.cs.concordia.ca/~gregb/home/soen343h-f06.html
Outline • GoF Design Patterns • Adapter, Façade, Strategy, Observer • Design Review
GoF Pattern Classification • Behavioral Patterns • Creational Patterns • Structural Patterns
Chain of Responsibility Command Interpreter Iterator Mediator Memento Observer State Strategy Template Method Visitor GoF Behavioral Patterns
GoF Creational Patterns • Abstract Factory • Builder • Factory Method • Prototype • Singleton
GoF Structural Patterns • Adapter • Bridge • Composite • Decorator • Facade • Flyweight • Proxy
Adapter • Context / problemHow to resolve incompatible interfaces, or provide a stable interface to similar components with different interfaces? • Solution:Convert the original interface of a component into another interface, through an intermediate adapter object.
Adapter • Suppose we have a tax calculation class (or external library) but the interface is not well suited for our application.
GoodAsGoldTaxProAdapter getTaxes( Sale ) : List of TaxLineItems GoodAsGoldTaxPro computeTax(…):double Adapter • Adapter providesan interface suitedto the application
Adapter (For More than One Class) • What if more than one class (library) needs to be adapted?
Strategy • Context / problem:How to design for varying, but related, algorithms or policies? How to design for the ability to change (even dynamically) these algorithms or policies? • Solution:Define each algorithm/policy/strategy in a separate class with a common interface
Observer • How shall we have the display be updated? • Why not …have the Sale inform the display when it changes value.
Observer Pattern • Context / Problem:Different kinds of subscriber objects are interested in the state changes or events of a publisher object, and want to react in their own way when the publisher generates the event. …
Observer Pattern • Solution:Define a “subscriber” or “listener” interface. Subscribers implement this interface. The publisher can dynamically register subscribers who are interested in an event, and notify them when an event occurs. • Clarification: Publisher can dynamically process registration requests from subscribers.
Recall … • Way back in week 5 we asked the question … How do I come up with a design?
How Do I Come Up With a Design? • What are the inputs to the activities of design? • What are the outputs?
Product requirements Project plan Architectural factors … ArchitectureDocument Architectural Style(s) … Design Activities: Inputs & Outputs
Design Input: SRS • What is contained in the SRS?(name some of its parts)
Domain Model Use Case Model Design Model Control Style / Pattern User-interface design … Design: From SRS to ...
Design Model Classes • Domain Model often used as first approximation to Design Model. • Domain Model contains • Conceptual classes • Conceptual classes used as basis for similarly named design classes. • (E.g. Larman, Chapter 16, p. 222.)
EA Patterns Page Controller Template View Presentation Front Controller Transform View Domain Model Transaction Script Domain Data Mapper Table Module Active Record Table Data Gateway Row Data Gateway Data Source
Requirements Domain Model Design Model: classes Domain Model pattern Enterprise Applications:Domain Model
Requirements artifacts: e.g. Domain Model Use Case Model Design artifacts: e.g. Software Architecture Document Design Model User-interface design … From Requirements to Design
Conceptual Classes to Design Classes • Domain Model pattern • Domain Model pattern
Representational Gap • Larman, Section 17.2: The object developer has taken inspiration from the real-world domain in creating software classes. Therefore, the representational gap between how stakeholders conceive the domain, and its representation in software, has been lowered.
From Rich Conceptual Domain Model to Rich set of Domain Model classes