Analysis and Design with UML: Discovering Classes and Relationships

Slides:



Advertisements
Similar presentations
Chapter 22 Object-Oriented Systems Analysis and Design and UML Systems Analysis and Design Kendall and Kendall Fifth Edition.
Advertisements

UML Class and Sequence Diagrams Violet Slides adapted from Marty Stepp, CSE 403, Winter 2012 CSE 403 Spring 2012 Anton Osobov.
Object-Oriented Analysis and Design
UML – Class Diagrams.
Basic OOP Concepts and Terms
7M701 1 Class Diagram advanced concepts. 7M701 2 Characteristics of Object Oriented Design (OOD) objectData and operations (functions) are combined 
2-1 © Prentice Hall, 2004 Chapter 2: Introduction to Object Orientation (Adapted) Object-Oriented Systems Analysis and Design Joey F. George, Dinesh Batra,
Introduction To System Analysis and design
OO Analysis and Design CMPS OOA/OOD Cursory explanation of OOP emphasizes ▫ Syntax  classes, inheritance, message passing, virtual, static Most.
UML Unified Modeling Language. What is UML? Unified Modeling Language (UML) is a standardized, general-purpose modeling language in the field of software.
Systems Analysis and Design in a Changing World, Tuesday, Feb 27
1 A Student Guide to Object- Orientated Systems Chapter 4 Objects and Classes: the basic concepts.
Object-Oriented Software Development F Software Development Process F Analyze Relationships Among Objects F Class Development F Class Design Guidelines.
CS3773 Software Engineering Lecture 04 UML Class Diagram.
Unified Modeling Language © 2002 by Dietrich and Urban1 ADVANCED DATABASE CONCEPTS Unified Modeling Language Susan D. Urban and Suzanne W. Dietrich Department.
Chapter 16 Applying UML and Patterns Craig Larman
1 Class Diagrams: Advanced Concepts. 2 Overview Class diagrams are the most commonly used diagrams in UML. Class diagrams are the most commonly used diagrams.
NJIT UML Class Diagrams Chapter 16 Applying UML and Patterns Craig Larman.
Basic OOP Concepts and Terms. In this class, we will cover: Objects and examples of different object types Classes and how they relate to objects Object.
What is a Structural Model?
Design Model Lecture p6 T120B pavasario sem.
Object Oriented Analysis: Associations. 2 Object Oriented Modeling BUAD/American University Class Relationships u Classes have relationships between each.
Object Oriented Analysis and Design Class and Object Diagrams.
 Week08.  Review Schedule Weeks 8-14  This week o Review last class o Introduce Class Diagrams o ICE-03 Sheridan SYST Engineering Quality Systems.
ITEC324 Principle of CS III Chapter 2 (Horstmann’s Book) – Part 1 The Object-Oriented Design Process Hwajung Lee.
12/24/2015B.Ramamurthy1 Analysis and Design with UML: Discovering Classes Bina Ramamurthy.
1 Introduction to Classes. 2 Terms and Concepts A class is... –The most important building block of any object- oriented system. –A description of a set.
 Class diagrams show the classes of the system, their interrelationships (including inheritance, aggregation, and association), and the operations and.
UML Fundamental Elements. Structural Elements Represent abstractions in our system. Elements that encapsulate the system's set of behaviors. Structural.
Chapter 2 (Horstmann’s Book) – Part 1 The Object-Oriented Design Process Hwajung Lee.
Data Modeling Using the Entity- Relationship (ER) Model
Chapter 12 – Object-Oriented Design
CHAPTER
Unified Modeling Language (UML)
Structural Modeling.
Business System Development
DATA REQIREMENT ANALYSIS
Chapter 5: Structural Modeling
Object-Oriented Analysis and Design
The Object-Oriented Thought Process Chapter 1
Entity-Relationship Model
Introduction to Unified Modeling Language (UML)
Object-Oriented Analysis
Analysis and Design with UML: Discovering Classes and Relationships
Unified Modeling Language
Dynamic Modeling: Defining Classes
Inheritance B.Ramamurthy 11/7/2018 B.Ramamurthy.
Advanced Java Programming
Introduction to UML Introduction to UML Shiyuan Jin September,23,2002
Analysis and Design with UML: Discovering Classes and Relationships
Software Engineering Lecture #11.
Object-Oriented Programming
Real-time (OO) Systems Design Using UML
Understand and Use Object Oriented Methods
Object-Oriented Programming
Enterprise Computing: An Overview
Unified Modeling Language
Systems Analysis – ITEC 3155 Modeling System Requirements – Part 2
Copyright 2007 Oxford Consulting, Ltd
Analysis and Design with UML: Classes and Relationships
Enterprise Computing: An Overview
Object-Oriented Programming
Basic OOP Concepts and Terms
Object Oriented Analysis and Design
Chapter 22 Object-Oriented Systems Analysis and Design and UML
Classes and Objects B.Ramamurthy 5/9/2019 B.Ramamurthy.
Object Oriented System Design Class Diagrams
UML  UML stands for Unified Modeling Language. It is a standard which is mainly used for creating object- oriented, meaningful documentation models for.
ITEC324 Principle of CS III
From Class Diagram to Contract Diagram
Presentation transcript:

Analysis and Design with UML: Discovering Classes and Relationships Bina Ramamurthy 7/4/2018 B.Ramamurthy

Introduction Purpose of this part is to transform the requirement analysis represented by the use-case diagram(s) to design diagrams using static analysis. The result of this phase is UML class diagrams consisting of classes and relationship among them. We will study techniques to discover classes and the UML notations for representing class diagrams. 7/4/2018 B.Ramamurthy

Topics for Discussion Classes, Responsibility, Collaboration (CRC) method for discovering classes and assigning responsibility. Class-based Analysis and Design: UML notations, class diagrams. Case Studies. 7/4/2018 B.Ramamurthy

CRC Card Method Although proponents of the object paradigm often say that identifying objects is a simple and intuitive process, a number of noted experts admit that this is not always true! … The solution is to use the CRC process to determine the classes necessary to the system as part of the design process for the application. CRC (classes, responsibility, and collaboration) cards can be used to visualize and test different class-based models during the design phase. It is a proven technique used and advocated by leading methodologists. 7/4/2018 B.Ramamurthy

CRC Card Class Name Collaborations Responsibilities 7/4/2018 B.Ramamurthy

CRC Card Example Weather Station Collaborations User Interface(UI) Responsibilities Date Time Temp Wind Pressure Humidity Calibrator Select 24hr/Current Set Date Time Display Current Temp(T) Wind (W) Pressure (P) Humidity (H) Display 24hours Hi/Lo for (TWPH) Display Trends in TWPH Calibrate 7/4/2018 B.Ramamurthy

CRC Card: UserInterface Collaborators Responsibilities Keypad Display Temp Wind Pressure Humidity Input date Input time Input selection Display data 7/4/2018 B.Ramamurthy

CRC Card: Keypad Collaborators Keypad Date Responsibilities Time Selection Responsibilities Store date Store time Store selection 7/4/2018 B.Ramamurthy

CRC Card: Temperature Temperature Collaborations Responsibilities Measure and Record temperature Determine and record Hi/Lo Determine trend T.Device StatDataBase Date Time 7/4/2018 B.Ramamurthy

Class Discovery The entries in the collaborations column are possible classes or non-software entities. In this case these are: UserInterface, Display, Tempertaure, Wind, Pressure, Humidity, StatDataBase, Selection, Date, Time, Keypad, Callibrator. The responsibility of designing one or more of these classes can be assigned to the members of the group who participated in this discovery process. On to relations among classes and class diagrams. 7/4/2018 B.Ramamurthy

Classes OO paradigm supports the view that a system is made up of objects interacting by message passing. Classes represent collection of objects of the same type. An object is an instance of a class. A class is defined by its properties and its behaviors. A class diagram describes the static view of a system in terms of classes and relationships among the classes. 7/4/2018 B.Ramamurthy

Discovering Classes (Alternative) Underline the nouns in a problem statement. Using the problem context and general knowledge about the problem domain decide on the important nouns. Design and implement classes to represent the nouns. Underline the verbs. Verbs related to a class may represent the behavior of the class. 7/4/2018 B.Ramamurthy

Examples Drawing package: Design a user interface for drawing various shapes: circle, square, rectangle. Football scores: Keep track of football score. General purpose counter: To keep of track of count for various applications. Library: Books, different categories of books, details of student borrower, library personnel. 7/4/2018 B.Ramamurthy

Designing Classes A class represents a class of objects. A class contains the data declarations (“parts”) and methods (“behaviors” or “capabilities” ). OO Design: Class properties or characteristics are answers to “What is it made of?” (It has a ____, ____, etc.) Behaviors, capabilities or operations are answers to “What can it do?” (verbs in the problem) 7/4/2018 B.Ramamurthy

Classes are Blueprints A class defines the general nature of a collection of objects of the same type. The process creating an object from a class is called instantiation. Every object is an instance of a particular class. There can be many instances of objects from the same class possible with different values for data. A class structure implements encapsulation as well as access control: private, public, protected. 7/4/2018 B.Ramamurthy

Example objects Object References redRose class Rose blueRose class 7/4/2018 B.Ramamurthy

Class Diagram : Automobile public: seat seatBelt accelerator private: sparkPlugs gear protected: gloveCompartment public: startEngine brake protected: transmission private: fuelInjection 7/4/2018 B.Ramamurthy

Automobile Class Using Rational Rose Tool 7/4/2018 B.Ramamurthy

Access Control Public, protected, private Public properties and behaviors are available to any other object to use/invoke Private: available only within the objects. Protected: available within the objects and to the class hierarchy inherited from the class. 7/4/2018 B.Ramamurthy

Relationships Typically an application consists of many related classes. Commonly used relationships include: associations, aggregations, and generalizations. We will look into other relationships later. 7/4/2018 B.Ramamurthy

Association An association is a connection between classes, a semantic connection between objects of classes involved in the association. Association typically represents “has a” or “uses” relationships. Indicated by a line, sometimes with arrow indicating unidirectional relationship, adorned by the name of the relation, and the ends of the line adorned by cardinality of relationship and optionally by the roles connected to each class. 7/4/2018 B.Ramamurthy

Association : Examples Uses Person Computer A person uses a computer. Owns Person Car 0..* A person may own many (zero..many) cars. 7/4/2018 B.Ramamurthy

Roles in Association drives Person Car driver company car A person (driver) drives a (company) car. wife Person husband married to 7/4/2018 B.Ramamurthy

Aggregation Aggregation represents a relation “contains”, “is a part of”, “whole-part” relation. Indicated by a line adorned on the “whole” by a hollow diamond Along with name of relationship and Cardinality. 7/4/2018 B.Ramamurthy

Aggregation: Example contains League Team * Membership aggregation: A league is made up of Many teams. 4 wheel made of Auto engine Strong aggregation. 1 part * 7/4/2018 B.Ramamurthy

Generalization Generalization is a relationship between a general and a specific class. The specific class called the subclass inherits from the general class, called the superclass. Public and protected properties (attributes) and behaviors (operations) are inherited. Design representation “inheritance” OO concept. 7/4/2018 B.Ramamurthy

Generalization: Symbol It represents “is a” relationship among classes and objects. Represented by a line with an hollow arrow head pointing to the superclass at the superclass end. 7/4/2018 B.Ramamurthy

Generalization: Example Vehicle Car Boat Truck 7/4/2018 B.Ramamurthy

Combined Example Person Vehicle Car Boat Truck drives 0..* 7/4/2018 B.Ramamurthy

Summary We looked at Class Diagrams which is very important part of UML Model, perhaps the only model used in many design representation. We also looked at two methods for class discovery(/analysis): CRC Card Method and Nouns-Verbs. Class diagrams directly represent the implementation (code) classes and the relationship among them. 7/4/2018 B.Ramamurthy