1 / 69

Chapter 12

Chapter 12. Object-Oriented Design. Objectives. To explain how a software design may be represented as a set of interacting objects that encapsulate their own state and operations. To describe the activities in the object-oriented design process. Objectives.

abner
Download Presentation

Chapter 12

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Chapter 12 Object-Oriented Design

  2. Objectives • To explain how a software design may be represented as a set of interacting objects that encapsulate their own state and operations. • To describe the activities in the object-oriented design process.

  3. Objectives • To introduce various models used to describe an object-oriented design • To show how the UML may be used to represent these models

  4. Topics covered • Objects and object classes • An object-oriented design process • Design evolution

  5. Characteristics of OOD • Allows designers to think in terms of interacting objects that maintain their own state and provide operations on that state instead of a set of functions operating on shared data. • Objects hide informationabout the represen-tation of state and hence limit access to it. • Objects may be distributed and may work sequentially or in parallel.

  6. A design strategy based on “information hiding”… Another way to think about “information hiding”: Potentially changeable design decisions are isolated (i.e., “hidden”) to minimize the impact of change. - David Parnas

  7. Interacting objects

  8. Advantages of OOD • Easier maintenance. Objects may be understood as stand-alone entities (and ripple effect is reduced). • Objects are appropriate reusable components. • For some systems, there is an obvious mapping from real world entities to system objects.

  9. Object-oriented development • OO Analysis: concerned with developing an object model of the application domain. • OO Design: concerned with developing an object-oriented system model to implement requirements • OO Programming: concerned with realising an OOD using an OO pro-gramming language such as Java or C++.

  10. The history of OO Development as reflected by Sommerville’s text • 1st Edition (1982): No mention of OO design! • 2nd Edition (1985): …it has been sug-gested that a better design methodology is OO design… To place such comments in perspective, many large systems have been built using top-down design. Few large systems have been built using an object-oriented approach.

  11. The history of OO Development as reflected by Sommerville’s text • 3rd Edition (1989): It is only within the past few years that an alternative mode of decomposition, OO design, has been recognized as of value.

  12. The history of OO Development as reflected by Sommerville’s text • 5th Edition (1995): Until relatively recently, the most commonly used software design strategy involved decomposing the design into functional components with system state infor-mation held in a shared data area…It is only since the late 1980’s that…OO design has been widely adopted.

  13. The history of OO Development as reflected by Sommerville’s text • 6th Edition(2001): An OO approach to the whole (of) software development is now commonly used… Coverage of functional design is now included in the new chapter on legacy systems.

  14. The history of OO Development as reflected by Sommerville’s text Although many software developers consider function-oriented design to be an outdated approach, OO development may not offer significant advantages (in some) situations. An interesting challenge…is to ensure that function-oriented and OO systems can work together.

  15. Objects and object classes • Objects are entities with state and a defined set of operations on that state. • State is represented as a set of object attributes. • Operations provide services to other objects when requested.

  16. Objects and object classes • Object classes are templates for objects. • An object classdefinition includes declarations of all attributes and operations associated with an object of that class. • They may inherit attributes and services from other object classes.

  17. The Unified Modeling Language • Several different notations for OOD were proposed in the 1980s and 1990s. (Booch, Rumbaugh, Jacobson, Coad & Yourdon, Wirfs, …) • UML is an integration of these notations. • It describes a number of different models that may be produced during OO analysis and design (user view, structural view, behavioural view, implementation view, …) • The de facto standard for OO modelling.

  18. Employee object class (UML) Object attributes Services to other objects

  19. Object communication • Conceptually, objects communicate by message passing. • Messages include: • The name of the service requested, • A copy of the information required to carry out the service, and • the name of a holder for the result of the service. • In practice, messages are often imple-mented by procedure calls

  20. Message examples // Call a method associated with a buffer // object that returns the next value // in the buffer v = circularBuffer.Get () ; // Call the method associated with a// thermostat object that sets the // temperature to be maintained thermostat.setTemp (20) ; Holder for result Name of service Info required

  21. Generalization and inheritance • Objects are members of classes which define attribute types and operations. • Classes may be arranged in a hierarchy where one class (a super-class) is a generalization of one or more other classes (sub-classes)

  22. Generalization and inheritance • A sub-class inherits the attributes and operations from its super class and may add new methods or attributes of its own.

  23. A UML generalisation hierarchy Definition on p. 18

  24. Advantages of inheritance • It is an abstraction mechanism which may be used to classify entities. • It is a reuse mechanism at both the design and the programming level. • The inheritance graph is a source oforganisational knowledge about domains and systems. (OO Analysis)

  25. Problems with inheritance • Object classes are not self-contained (i.e., they cannot be understood without reference to their super-classes). • Designers have a tendency to reuse the inheritance graph created during analysis. (Inheritance graphs of analysis, design and implementation have different functions.) Due to inherited attributes/ops Discipline/education problem?

  26. Inheritance and OOD • Inheritance is a useful implementation concept which allows reuse of attribute and operation definitions. • Some feel that identifying an inheritance hierarchy or network is also a funda-mental part of object-oriented design.(Obviously, this can only be implemented directly using an OOPL.)

  27. Inheritance and OOD • Others feel this places unnecessary restrictions on the implementation.* • Inheritance introduces complexity and this is undesirable, especially in critical systems. * This appears to be Sommerville’s view

  28. UML associations • Objects and object classes participate in various types of relationships with other objects and object classes. • In the UML, a generalized relationship is indicated by an association.

  29. UML associations • Associations may be annotated with information that describes their nature. • Associations can be used to indicate that an attribute of an object is an associated object or that a method relies on an associated object. (semantics)

  30. An association model annotations

  31. Concurrent objects • The nature of objects as self-contained entities make them well suited for con-current implementation. • The message-passing model of object communication can be implemented directly if objects are running on separate processors in a distributed system. (as opposed to using procedure calls)

  32. Concurrent object implementation: servers and active objects • Servers (Passive objects):implemented as parallel processes with entry points correspon-ding to object operations. If no calls are made to it, the object suspends itself and waits for further requests for service. • Active objects:implemented as parallel processes and the internal object state may be changed by the object itself and not simply by external calls.

  33. Example: an active transponder object • A transponder object broadcasts an aircraft’s position.(on demand) • The object periodically updates the position by triangulation from satellites. (autonomously)

  34. An active transponder object Java-based interface description ON DEMAND IN BACKGROUND

  35. Active object implementation: Java threads, Ada tasks, etc. • Threads in Java are a simple construct for implementing concurrent objects. • Threads must include a method called run() and this is started up by the Java run-time system. • Active objects typically include an infinite loop so that they are always carrying out the computation.

  36. An object-oriented design process(an iterative, boot-strapping process) • Define the context and modes of use of the system. • Design the system architecture. • Identify the principal system objects. • Develop design models (static and dynamic). • Specify object interfaces.

  37. Weather system description A weather data collection system is required to generate weather maps on a regular basis using data collected from remote, unattended weather stations and other data sources such as weather observers, balloons and satellites. Weather stations transmit their data to the area computer in response to a request from that machine.

  38. Weather system description The area computer validates the collected data and integrates it with the data from different sources. The integrated data is archived and, using data from this archive and a digitised map database a set of local weather maps is created. Maps may be printed for distribution on a special-purpose map printer or may be displayed in a number of different formats.

  39. Weather station description A weather station is a package of software controlled instruments which collects data, performs some data processing and transmits this data for further processing. The instruments include air and ground thermometers, an anemometer, a wind vane, a barometer and a rain gauge. Data is collected every five minutes.

  40. Weather station description When a command is issued to transmit the weather data, the weather station processes and summarises the collected data. The summarised data is transmitted to the mapping computer when a request is received.

  41. Define system context and modes of use • Goal: develop an understanding of the relationships between the software being designed and its external environment. • System context: a static model that describes other systems in the environ-ment. • The context of the weather station is illustrated below using UML packages.

  42. Context of weather station

  43. Define system context and modes of use (cont.) • Modes of system use: a dynamic model that describes how the system will interact with its environment. • Modes of weather station use are illustrated below using a UML use-case model.

  44. Use-cases for the weather station External entity (weather data collection sys) Possible interactions

  45. Use-case description basis for “information hiding”

  46. Design system architecture • A layered architecture is appropriate for the weather station: • Interface layer for handling communications • Data collection layer for managing instruments • Instruments layer for collecting data • Rule of Thumb: There should be no more than 7 entities in an architectural model. (See Miller, "The Magical Number Seven, Plus or Minus Two,“ WOR. )

  47. Weather station architecture UML annotations UML “nested packages”

  48. Identify principal system objects • Identifying objects (or object classes) is the most difficult part OO design. • There is no “magic formula” – it relies on the skill, experience, and domain knowledge of system designers • An iterative process – you are unlikely to get it right the first time.

  49. Approaches to object identification • Use a grammatical approach based on a natural language description of the system (Abbott’s heuristic). • Associate objects with tangible things in the application domain (e.g. devices). • Use a behavioural approach: identify objects based on what participates in what behaviour.

  50. Approaches to object identification (cont.) • Use scenario-based analysis. The objects, attributes and methods in each scenario are identified. • Use an information-hiding based approach.* Identify potentially change-able design decisions and isolate these in separate objects. * “Bonus” approach! (No extra charge.)

More Related