Teamwork Know each other Compete Leadership Strengths and Weaknesses

Slides:



Advertisements
Similar presentations
Object-Oriented Design
Advertisements

©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design 1.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Software Design l Objectives To explain how a software design may be represented.
Informática II Prof. Dr. Gustavo Patiño MJ
Chapter 7 – Object-Oriented Design
SWE Introduction to Software Engineering
Introduction To System Analysis and Design
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
7M701 1 Software Engineering Object-oriented Design Sommerville, Ian (2001) Software Engineering, 6 th edition: Chapter 12 )
Object-oriented Design
1 SWE Introduction to Software Engineering Lecture 23 – Architectural Design (Chapter 13)
Modified from Sommerville’s originalsSoftware Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
Chapter 14: Object-Oriented Design
Soft. Eng. II, Spr. 2002Dr Driss Kettani, from I. Sommerville1 CSC-3325: Chapter 7 Title : Object Oriented Analysis and Design Reading: I. Sommerville,
7M701 1 Class Diagram advanced concepts. 7M701 2 Characteristics of Object Oriented Design (OOD) objectData and operations (functions) are combined 
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented design 2.
©Ian Sommerville 2006Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
Component-Level Design
Copyright 2004 Prentice-Hall, Inc. Essentials of Systems Analysis and Design Second Edition Joseph S. Valacich Joey F. George Jeffrey A. Hoffer Appendix.
Chapter 3 Object-Oriented Analysis of Library Management System(LMS)
CMPT 275 Software Engineering
Introduction To System Analysis and design
With a focus on OO design techniques
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 7 Slide 1 System models l Abstract descriptions of systems whose requirements are being.
1 CS 456 Software Engineering. 2 Contents 3 Chapter 1: Introduction.
Object-Oriented Design Yonsei University 2 nd Semester, 2014 Woo-Cheol Kim.
Copyright 2001 Prentice-Hall, Inc. Essentials of Systems Analysis and Design Joseph S. Valacich Joey F. George Jeffrey A. Hoffer Appendix A Object-Oriented.
Unified Modeling Language, Version 2.0
Introduction To System Analysis and Design
Lecture 3 Uses Cases Topics UML Use Cases pop quiz Readings: Chapter 3 January 24, 2008 CSCE 492 Software Engineering.
CSC480 Software Engineering Lecture 11 September 30, 2002.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design Sumber dari : cc.ee.ntu.edu.tw/~farn/courses/SE/ch14.ppt.
Software Engineering, 8th edition Chapter 14 1 Courtesy: ©Ian Somerville 2006 April 13 th, 2009 Lecture # 16 Object-oriented Design.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Object-oriented Design Designing systems using self- contained objects and object.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Chapter 12 Object-Oriented Design.
CMSC 345 Fall 2000 Design. What is Design? Verb: The creative process of transforming the problem into the solution Noun: The description of the solution.
1 Object-oriented Design Designing systems using self- contained objects and object classes.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Object-oriented Design Designing systems using self- contained objects and object.
 To explain how a software design may be represented as a set of interacting objects that manage their own state and operations  To describe the activities.
Lecture 1: Introduction to Software Engineering WXGE6103 Software Engineering Process and Practice Object-oriented Design.
CS.436 Software Engineering By Ajarn..Sutapart Sappajak,METC,MSIT Chapter 10 Object-oriented Design Slide 1 1 Chapter 10 Object-oriented Design.
1/26 On-demand Learning Series Software Engineering of Web Application - Object-Oriented Development & UML Hunan University, Software School.
Object-oriented Design Designing systems using self-contained objects and object classes Designing systems using self-contained objects and object classes.
Chap 10. Object-oriented Design - Designing systems using self-contained objects and object classes -
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Assignment # 3 Due at Class 3/17 l Chapter 9: 2 and 9 l Chapter 11: 1, 4 and.
14. Object-Oriented Design Software Engineering. Objectives To explain how a software design may be represented as a set of interacting objects that manage.
12/2/2015 1www.prsolutions08.blogspot.com Object-oriented Design.
OBJECT ORIENTED AND FUNCTION ORIENTED DESIGN 1 Chapter 6.
1 High Level Design Phase Refining Use Cases User Interface Information.
Object-oriented Design. Recap The software architect is responsible for deriving a structural system model, a control model and a sub-system decomposition.
© 2001 Franz Kurfess Object-oriented Design 1 CPE/CSC 205: Software Engineering I Dr. Franz J. Kurfess Computer Science Department Cal Poly.
Chapter 5 System Modeling. What is System modeling? System modeling is the process of developing abstract models of a system, with each model presenting.
CMSC 345 Fall 2000 OO Design. Characteristics of OOD Objects are abstractions of real-world or system entities and manage themselves Objects are independent.
Slide 1 Chapter 10 Object-oriented Design. Slide 2 Characteristics of OOD l Objects are abstractions of real-world or system entities and manage themselves.
Copyright © 2009 Pearson Education, Inc. Publishing as Prentice Hall Appendix A Object-Oriented Analysis and Design A.1.
Object-oriented Design 3/3/20161ICS 413 – Software Engineering.
CHAPTER 6: OBJECT-ORIENTED DESIGN. Objectives  To explain how a software design may be represented as a set of interacting objects that manage their.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
Chapter 14. Objectives To explain how a software design may be represented as a set of interacting objects that manage their own state and operations.
Chapter 2: Component Level Design
Chapter 7 – Object-Oriented Design
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Chapter 12 Object-Oriented Design.
Software Engineering Unit- 5 Engineered for Tomorrow CSE, MVJCE.
Object-oriented Design
Object- Oriented Design
With a focus on OO design techniques
Object-oriented Design
Presentation transcript:

Teamwork Know each other Compete Leadership Strengths and Weaknesses Schedules Preferences Compete With other groups With each other Leadership Emergent Social/Technical

Characteristics of OOD Objects are abstractions of real-world or system entities and manage themselves Objects are independent and encapsulate state and representation information. System functionality is expressed in terms of object services Shared data areas are eliminated. Objects communicate by message passing Objects may be distributed and may execute sequentially or in parallel

Advantages of OOD Easier maintenance. Objects may be understood as stand-alone entities Objects are appropriate reusable components For some systems, there may be an obvious mapping from real world entities to system objects

Object-oriented development Object-oriented analysis, design and programming are related but distinct OOA is concerned with developing an object model of the application domain OOD is concerned with developing an object-oriented system model to implement requirements OOP is concerned with realising an OOD using an OO programming language such as Java or C++

Objects and object classes Objects are entities in a software system which represent instances of real-world and system entities Object classes are templates for objects. They may be used to create objects Object classes may inherit attributes and services from other object classes

Objects An object is an entity which has a state and a defined set of operations which operate on that state. The state is represented as a set of object attributes. The operations associated with the object provide services to other objects (clients) which request these services when some computation is required. Objects are created according to some object class definition. An object class definition serves as a template for objects. It includes declarations of all the attributes and services which should be associated with an object of that class.

The Unified Modeling Language Several different notations for describing object-oriented designs were proposed in the 1980s and 1990s The Unified Modeling Language is an integration of these notations It describes notations for a number of different models that may be produced during OO analysis and design It is now a de facto standard for OO modelling

Employee object class (UML)

Object communication Conceptually, objects communicate by message passing. Messages The name of the service requested by the calling object. Copies of the information required to execute the service and the name of a holder for the result of the service. In practice, messages are often implemented by procedure calls Name = procedure name. Information = parameter list.

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) ;

Generalisation and inheritance Objects are members of classes which define attribute types and operations Classes may be arranged in a class hierarchy where one class (a super-class) is a generalisation of one or more other classes (sub-classes) A sub-class inherits the attributes and operations from its super class and may add new methods or attributes of its own Generalisation in the UML is implemented as inheritance in OO programming languages

A generalisation hierarchy

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 of organisational knowledge about domains and systems

UML associations Objects and object classes participate in relationships with other objects and object classes In the UML, a generalised relationship is indicated by an association Associations may be annotated with information that describes the association Associations are general but may indicate that an attribute of an object is an associated object or that a method relies on an associated object

An association model

Concurrent objects The nature of objects as self-contained entities make them suitable for concurrent implementation The message-passing model of object communication can be implemented directly if objects are running on separate processors in a distributed system

Servers and active objects The object is implemented as a parallel process (server) with entry points corresponding to object operations. If no calls are made to it, the object suspends itself and waits for further requests for service Active objects Objects are implemented as parallel processes and the internal object state may be changed by the object itself and not simply by external calls

Active transponder object Active objects may have their attributes modified by operations but may also update them autonomously using internal operations Transponder object broadcasts an aircraft’s position. The position may be updated using a satellite positioning system. The object periodically updates the position by triangulation from satellites

An active transponder object

Java threads 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

Blank

An object-oriented design process Define the context and modes of use of the system Design the system architecture Identify the principal system objects Develop design models Specify object interfaces

Use Cases – System behavior Use-cases are a scenario based technique which identify the actors in an interaction and which describe the interaction A set of use cases should describe all possible interactions with the system Other types of UML diagrams can add detail to use cases

Use cases Specify system behavior without specifying implementation Focus on interaction with users Validate understanding of requirements Decompose system into coherent categories of functionality

Use cases and informal scenarios More abstract than informal scenarios. Avoids reference to specific values A single use-case usually encompasses multiple scenarios More formal Express the complete breadth of functionality of system

LMS – identifying use cases Check out resource Return resource Request resource Reserve resource … Generate form letter

Use case format -- LMS Use Case: Check out resource Precondition: The Library staff has successfully identified herself to the library system by entering a valid library staff identification and password. A library database, containing information concerning the library holdings and the patrons of the library, has been created and initialized.

Use case format - LMS Main flow of events: The use case starts when the Library staff requests the Check out resource function from the system main menu. The system then initiates the Validate patron use case. If that use case ends successfully and a valid patron id has been entered into the system, the system initiates the Enter resource use case. If the Enter resource use case ends successfully, the Determine due date use case is initiated. The Enter resource and Determine due date use-case-pair is executed over and over until the Library staff commits the entry by pressing the enter key. The system then displays a list of valid resources that have been entered along with due dates for each resource. This ends the Check out resource use case.

Use case format -- LMS Exceptional flow of events: If the Validate patron use case does not end with a valid patron id being entered, the system cancels the entire transaction and this use case ends Exceptional flow of events: if the Enter resource use case does not end with a valid resource Dewey call number having been entered, the system displays an appropriate warning message and continues the Check out resource use case by skipping the Determine due date use case and initiating the next instance of the Enter resource use case.

Use case format -- LMS Postcondition: If the Validate patron use case does not end with a valid patron id being entered, nothing in the entire system has changed when this use case ends. If a valid library patron id was entered, then the Patron object is updated with the Dewey call numbers of the Resource objects that have been checked out along with their due dates. In addition, the Resource objects are updated to have a status of checked-out along with the library id of the Patron who check it out.

Use Case: Validate Patron Precondition: Patron needs some service Main flow of events: The use case starts when the system prompts the Library staff for the Patron’s library id. The Library staff can either scan in a card or type in an id and then commit the entry by pressing the enter key. The system then checks to see if the id is valid. If it is valid the system displays the library record for Patron, thus ending this use case

Use case – Validate patron Exceptional flow of events: If the Library staff enters an invalid library id, the system cancels the entire transaction and this use case ends Exceptional flow of events: If the Library staff enters a library id that has expired then the system cancels the entire transaction and this use case ends Exceptional flow of events: If the Patron has too many resources checked out, he or she may not check out any additional resources. A message that tallies and lists the resources currently held by Patron is displayed on the screen and this use case ends

Use case – Validate patron Exceptional flow of events: If the Patron has any library resources that are more than two weeks overdue, then these resources are listed on the screen and this use case ends. Postcondition: The system retrieves and displays the library record of the Patron. The system’s state has not changed.

Architectural design Once interactions between the system and its environment have been understood, you use this information for designing the system architecture There should be no more than 7 entities in an architectural model

Key points OOD is an approach to design so that design components have their own private state and operations Objects should have constructor and inspection operations. They provide services to other objects Objects may be implemented sequentially or concurrently The Unified Modeling Language provides different notations for defining different object models

Key points A range of different models may be produced during an object-oriented design process. These include static and dynamic system models Object-oriented design simplifies system evolution