Cmpe 589 Spring 2006
Object Oriented Analysis Class modeling. (Build an object model similar to an ER diagram) Dynamic modeling. (Build a finite state machine type model) Functional modeling. (Similar to data flow diagram)
Object Oriented Analysis Case Study: Elevator model. n - elevators. m - floors in building. each floor has two buttons (except ground & top).
Object Oriented Analysis Class Modeling Buttons. Elevators. Floor. Building. Movement. Illumination. Doors. Requests.
Object Oriented Analysis
Object Oriented Analysis Dynamic Modeling: "Normal" schemas (and 1 or 2 abnormal). production rules (describe state transitions).
Object Oriented Analysis Functional Modeling: (Identify source & destination node)
Object Oriented Life Cycle Model Fountain Model:
Class Responsibility Collaborator Model (CRC): Responsibilities: Distributed system intelligence. State responsibility in general terms. Information and related behavior in same class. Information attributes should be localized. Share responsibilities among classes when appropriate. Collaborators build a CRC card (Build a paper model, see if it works on paper) On card: Class name. Class type. Class characteristics. Responsibility/collaborators. (System is basically acted out)
O.O.D. (Booch – Abbot Method): Define problem. Develop process narrative for software realization of problem domain. Formalize strategy. Identify object & attributes. Identify operations which can be applied to objects. Establish interfaces by showing relationships between objects and operations. Resolve design details to allow implementation. Recursively apply (2) & (3). Refine work done during O.O.A.. Represent data structures associated with object attributes. Represent procedural derail for each operation.
O.O.D. (Booch – Abbot Method): Operator Classifications: Data manipulator (add, delete, format). Computation. Monitors.
Basic Notation For O.O.D.: Class diagram (static).
Basic Notation For O.O.D.: Object diagram (dynamic). (communication)
Basic Notation For O.O.D.: Object module diagram.
Basic Notation For O.O.D.: Process diagram.
Alternative Generic Approach to O.O.D.:Object Oriented Analysis Identify the data abstraction for each sub-system. Identify attributes for each data abstraction. Identify operations for each data abstraction. Identify communication between objects. Apply inheritance where appropriate.
Object Oriented Program Design: Undertake object oriented system requirements specification. Identify object and their services. Establish interactions between objects (services required & rendered). Identification of reusable components from previous design. Implementation of low level objects. Introduce inheritance relationships (superclass & subclass). Class combination and generalization. (prototype revision – change is healthy)
Common Design Flaws: (too much junk in the class) Classes that make direct modifications to other classes. Classes with too much responsibility. Classes with no responsibility. Classes with unused responsibility . (too much junk in the class) Misleading names. Unconnected responsibility. Inappropriate inheritance. Repeated functionality.
Object Oriented Analysis Object Oriented Design Object. (Class = type vs. Instance = var) Encapsulation (Data & methods) Message passing. (Method call & return) Inheritance. (Polymorphism & reuse) Dynamic bindings. (Types & methods)
Identify the problem objects (classes) = nouns (not procedure names) Example: External entities (people & devices). Things in problem domain (reports, displays, signals). Occurrences or events (completion of some task). Roles (manager, engineer, sales person). Organizational units (division, groups, department). Structures (sensors, vehicles, computers).
Object Oriented Analysis Criteria: (Object or not) Does object inf. need to be retained? Does object have a set of needed services? (Can change it’s attributes) Does the object have major attributes? (Trivial objects should not be built) Identify common attributes for all object instances. Identify common operations for all object instances. (If nothing to share, why make it an object?) External entities which produce or consume must have defined classes.
Object Oriented Analysis Specifying Attributes: Similar to building data dictionary. (define in terms of atomic objects)
Object Oriented Analysis Include anything needed to manipulate data elements Communication among objects.
Object Oriented Analysis Object Specification: Object name. Attribute description: Attribute name. Attribute content. Attribute data type/structure. External input to object. External output from object. Operation description: Operation name. Operation interface description. Operation processing description. Performance issues. Restriction and limitations. Instance connections: (0:1, 1:1, 0:many, 1:many) Message connections.
Object Oriented Design: Private data & related operations. Shared part (interface). Advantages: Modularity is inherent Decomposability (problem -> sub-problem). Composability (reusability of pieces). Understandability (with respect to independence). Continuity (easy to change). Protection (encapsulation).
Object Oriented Design: Design Principles For Modularity: Linguistic modular units. (ADT’s should be supported) Few interfaces. Small interfaces (weak coupling). Explicit interfaces (parameter – not common coupling). Information hiding.
Object Oriented Analysis