GRASP
GRASP GRASP: an acronym that stands for General Responsibility Assignment Software Patterns I think a RAP is a better acronym. Do the words general & software pull their weight?
The 9 GRASP Information Expert Creator Information expert: the class that has the information necessary to fulfill the responsibility. Assign a responsibility to the information expert. Creator Who creates instances of class A? Class B when: B has A[s] B is an information expert for A (has the constructor arguments).
The 9 GRASP … Controller Low coupling High cohesion Who handles a system event? The system’s façade [controller] class. Low coupling Minimize inter-class coupling High cohesion Maximize intra-class cohesion
The 9 GRASP: Polymorphism To vary a general behavior by class: Extend a base class Implement an interface Example: Command pattern. The Lectures page has ServiceImpl.java Jicos has around 60 different Commands
The 9 GRASP: Pure Fabrication Assign a highly cohesive set of responsibilities to a class that is: Created to support OOD: High cohesion Low coupling Examples Façade, adaptor, & bridge patterns are pure fabrications that lower coupling
The 9 GRASP: Indirection Mediate: Acting through an intervening agent. To interpose between parties, esp. to effect an agreement; as, to mediate between nations. A client/service mediator class. Lowers coupling Examples: Façade, Adaptor, Bridge (Sound familiar? ) Client Mediator Service
The 9 GRASP: Protected Variations Define a stable interface to hide an area of instability. Yes: List list = new ArrayList(); // java.util.List not java.awt.List No: ArrayList list = new ArrayList(); for ( Iterator i = c.iterator(); i.hasNext(); ) { doSomething( i.next() ); } Java List, Map interfaces.