UML Class Diagram and Packages

Slides:



Advertisements
Similar presentations
Object-oriented modeling Class/Object Diagrams
Advertisements

Stereotypes Stereotypes provide the capability to create a new kind of modeling element. –They can be used to classify or mark modeling elements. –A type.
CRC Modeling. Recap Class Modeling – How to Identify classes, its attributes and functions? – Class selection criteria – Relationships Associations Generalization.
UML Class Diagram. UML Class Diagrams2 Agenda What is a Class Diagram? Essential Elements of a UML Class Diagram Tips.
UML Class Diagram and Packages Written by Zvika Gutterman Adam Carmi.
UML Class Diagram. UML Class Diagrams2 Agenda What is a Class Diagram? Essential Elements of a UML Class Diagram Tips.
UML – Class Diagrams.
UML Class Diagram and Packages Written by Zvika Gutterman Adam Carmi.
UML Class Diagram and Packages Written by Zvika Gutterman Adam Carmi.
What is UML? A modeling language standardized by the OMG (Object Management Group), and widely used in OO analysis and design A modeling language is a.
7M701 1 Class Diagram advanced concepts. 7M701 2 Characteristics of Object Oriented Design (OOD) objectData and operations (functions) are combined 
Unified Modeling Language (UML)
Practical Object-Oriented Design with UML 2e Slide 1/1 ©The McGraw-Hill Companies, 2004 Class and Object Diagrams PRACTICAL OBJECT-ORIENTED DESIGN WITH.
7M822 UML Class Diagrams advanced concepts 15 September 2008.
Modelling classes Drawing a Class Diagram. Class diagram First pick the classes –Choose relevant nouns, which have attributes and operations. Find the.
1 Object-Oriented Modeling Using UML CS 3331 Fall 2009.
UML Class Diagrams: Basic Concepts. Objects –The purpose of class modeling is to describe objects. –An object is a concept, abstraction or thing that.
Unified Modeling Language
Unified Modeling Language
Object-Oriented Analysis and Design
OBJECT ORIENTED PROGRAMMING LECTURE 12 Instructor: Rashi Garg Coordinator: Gaurav Saxena.
Class Diagram.
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.
Databases : Data Modeling 2007, Fall Pusan National University Ki-Joune Li.
بسم الله الرحمن الرحيم ” اللهم أنت ربي لا إله إلا أنت خلقتني و أنا عبدك وأنا على عهدك ووعدك ما استطعت ، أعوذ بك من شر ما صنعت ، أبوء لك بنعمتك على و أبوء.
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
® IBM Software Group © 2006 IBM Corporation Rational Software France Object-Oriented Analysis and Design with UML2 and Rational Software Modeler 03. Classes,
Class-based Modeling.
SOFTWARE DESIGN AND ARCHITECTURE LECTURE 24. Review ANALYSIS Level Class Diagram – Identifying Entities – Identifying Attributes – Identifying Operations.
Fall 2010 CS4310 Requirements Engineering A Brief Review of UML & OO Dr. Guoqiang Hu Department of Computer Science UTEP 1.
Class diagram Used for describing structure and behaviour in the use cases Provide a conceptual model of the system in terms of entities and their relationships.
UML Class Diagram Trisha Cummings. What we will be covering What is a Class Diagram? Essential Elements of a UML Class Diagram UML Packages Logical Distribution.
NJIT UML Class Diagrams Chapter 16 Applying UML and Patterns Craig Larman.
An Introduction to the Unified Modeling Language
UML The Unified Modeling Language A Practical Introduction Al-Ayham Saleh Aleppo University
Lecture 1: UML Class Diagram September 12, UML Class Diagrams2 What is a Class Diagram? A class diagram describes the types of objects in the system.
Class Diagram. Classes Software Design (UML) Class Name attributes operations A class is a description of a set of objects that share the same attributes,
Chapter 5 System Modeling Sommerville, "software engineering ", 9 th Ed., 2011.
Design Model Lecture p6 T120B pavasario sem.
Relationships Relationships between objects and between classes.
Object Oriented Analysis: Associations. 2 Object Oriented Modeling BUAD/American University Class Relationships u Classes have relationships between each.
Object-Oriented Modeling: Static Models. Object-Oriented Modeling Model the system as interacting objects Model the system as interacting objects Match.
CSCI-383 Object-Oriented Programming & Design Lecture 10.
Class Diagram Chapter 21 Applying UML and Patterns Craig Larman.
CS212: Object Oriented Analysis and Design Lecture 33: Class and Sequence Diagram.
Chapter 16: UML Class Diagrams
Chapter 16 UML Class Diagrams 1CS6359 Fall 2012 John Cole.
ITEC0724 Modern Related Technology on Mobile Devices Lecture Notes #2 1.
UML Class Diagrams Sequence Diagrams CSE230 Dae-Kyoo Kim.
Class Diagram Lecture # 1. Class diagram A Class Diagram is a diagram describing the structure of a system shows the system's classes Attributes operations.
UML Fundamental Elements. Structural Elements Represent abstractions in our system. Elements that encapsulate the system's set of behaviors. Structural.
Data Modelling 2014, Fall Pusan National University Ki-Joune Li.
Unified Modeling Language (UML)
COMP 2710 Software Construction Class Diagrams
DEPARTMENT OF COMPUTER SCIENCE AND ENGINEERING
Class diagram Description
UML Unified Modelling Language
UML Class Diagrams: Basic Concepts
Object Oriented Analysis and Design
Lec 3: Object-Oriented Data Modeling
2018, Fall Pusan National University Ki-Joune Li
UML Class Diagram.
Unified Modelling Language
Software Engineering System Modeling Extra examples Dr.Doaa Sami
Class Diagrams Class diagram is basically a graphical representation of the static view of the system and represents different aspects of the application.
Object Oriented System Design Class Diagrams
Information System Design
2019, Fall Pusan National University Ki-Joune Li
Presentation transcript:

UML Class Diagram and Packages Written by Zvika Gutterman Adam Carmi

Agenda What is a Class Diagram? Essential Elements of a UML Class Diagram UML Packages Logical Distribution of Classes Packages and Class Diagrams Tips

What is a Class Diagram? A class diagram describes the types of objects in the system and the various kinds of static relationships that exist among them. A graphical representation of a static view on declarative static elements. A central modeling technique that runs through nearly all object-oriented methods. The richest notation in UML.

Essential Elements of a UML Class Diagram Attributes Operations Relationships Associations Generalization Dependency Realization Constraint Rules and Notes

Classes A class is the description of a set of objects having similar attributes, operations, relationships and behavior. Class Name Window size: Size visibility: boolean display() hide() Window size: Size visibility: boolean Window Attributes No inference can be drawn about the presence or absence of elements in a missing compartment Operations

Attributes Classes have attributes that describe the characteristics of their objects. Attributes are atomic entities with no responsibilities. Attribute syntax (partial): [visibility] name [ : type ] [ = defaultValue ] Class scope attributes are underlined

Attributes (cont.) Example (Java implementation): + author: String = “unknown” + text : String - total : long = 0 Note public class Note { public String author = “unknown”; public String text; private static long total = 0; ... }

Operations Operations are the processes that objects of a class (or the class itself) know to carry out. Operations correspond to method declarations rather than method definitions. Operation syntax (partial): [ visibility ] name ( [ parameter-list ] ) [ : return-type ] where parameter-list is a comma separated list of formal parameters, each specified using the syntax: name : type [ = defaultValue ] Example: max(a : int, b : int) : int

Operations (cont.) Class scope operations are underlined. Java implementation: public class Figure { private Size size; private Position pos; private static long figureCount = 0; public void move(Position pos) { ... } public static long getFigureCount() { return figureCount; } ... } Figure - size: Size - pos : Position + move(pos : Position) + getFigureCount() : long

Visibility Visibility describes whether an attribute or operation is visible and can be referenced from classes other than the one in which they are defined. language dependent Means different things in different languages UML provides four visibility abbreviations: + (public) – (private) # (protected) ~ (package)

Associations A semantic relationship between two or more classes that specifies connections among their instances. A structural relationship, specifying that objects of one class are connected to objects of a second (possibly the same) class. Example: “An Employee works for a Company” Company Department Employee semantic Employee Company structural

Associations (cont.) An association between two classes indicates that objects at one end of an association “recognize” objects at the other end and may send messages to them. This property will help us discover less trivial associations using interaction diagrams.

Navigable (uni-directional) association Reflexive association Associations (cont.) Role name Association name instructor StaffMember Student 1..* instructs * Role Navigable (uni-directional) association Multiplicity * pre - requisites Courses 0..3 Reflexive association

Associations (cont.) To clarify its meaning, an association may be named. The name is represented as a label placed midway along the association line. Usually a verb or a verb phrase. A role is an end of an association where it connects to a class. May be named to indicate the role played by the class attached to the end of the association path. Usually a noun or noun phrase Mandatory for reflexive associations

Associations (cont.) Multiplicity The number of instances of the class, next to which the multiplicity expression appears, that are referenced by a single instance of the class that is at the other end of the association path. Indicates whether or not an association is mandatory. Provides a lower and upper bound on the number of instances.

Associations (cont.) Multiplicity Indicators Exactly one 1 Zero or more (unlimited) * (0..*) One or more 1..* Zero or one (optional association) 0..1 Specified range 2..4 Multiple, disjoint ranges 2, 4..6, 8

Aggregation A special form of association that models a whole-part relationship between an aggregate (the whole) and its parts. Models a “is a part-part of” relationship. Car Door House 1..* 2..* Whole Part

Aggregation (cont.) Aggregation tests: Is the phrase “part of” used to describe the relationship? A door is “part of” a car Are some operations on the whole automatically applied to its parts? Move the car, move the door. Are some attribute values propagated from the whole to all or some of its parts? The car is blue, therefore the door is blue. Is there an intrinsic asymmetry to the relationship where one class is subordinate to the other? A door is part of a car. A car is not part of a door.

Aggregation (cont.) Java implementation: public class Car { private Vector doors = new Vector(); public void addDoor(Door door) { ... } ... } public static void main(String[] args) { Door door = new Door(); House house = new House(door); Car car = new Car(); car.addDoor(door); ... }

Composition A strong form of aggregation The whole is the sole owner of its part. The part object may belong to only one whole Multiplicity on the whole side must be zero or one. The life time of the part is dependent upon the whole. The composite must manage the creation and destruction of its parts. Circle Point 3..* 1 Polygon Point Circle

Composition (cont.) C++ implementations: class Circle { public: Circle() : center(1,2) {} private: Point center; }; class Circle { public: Circle() : center(new Point(1,2)) {} ~Circle() { delete center; } private: Point* const center; };

Generalization relationship Indicates that objects of the specialized class (subclass) are substitutable for objects of the generalized class (super-class). “is kind of” relationship. {abstract} is a tagged value that indicates that the class is abstract. The name of an abstract class should be italicized Shape {abstract} Circle Super Class Sub Class An abstract class Generalization relationship

Generalization A sub-class inherits from its super-class Attributes Operations Relationships A sub-class may Add attributes and operations Add relationships Refine (override) inherited operations A generalization relationship may not be used to model interface implementation.

Generalization Java implementation: Shape {Abstract} Circle draw() { abstract } public abstract class Shape { public abstract void draw(); ... } public class Circle extends Shape { public void draw() { ... } ... } Circle draw()

Dependency A dependency is a relation between two classes in which a change in one may force changes in the other although there is no explicit association between them. A stereotype may be used to denote the type of the dependency. Iterator <<friend>> Vector

Dependency (cont.) Examples: A class calls a class scope operation of another class. A class is a friend of another class. A class depends on the interface of another class. A class contains an operation that takes an object of another class as a parameter. A class accesses a global object of another class.

<<interface>> List Realization A realization relationship indicates that one class implements a behavior specified by another class (an interface or protocol). An interface can be realized by many classes. A class may realize many interfaces. LinkedList <<interface>> List LinkedList List

Realization (cont.) Java implementation: public interface List { boolean add(Object o); ... } public class LinkedList implements List { public boolean add(Object o) { ... } ... }

Constraint Rules and Notes Constraints and notes annotate among other things associations, attributes, operations and classes. Constraints are semantic restrictions noted as expressions. UML offers many pre-defined constraints. id: long { value > 0 } Customer Order * 1 { total < $50 } may be canceled Constraint Note

UML Packages A package is a general purpose grouping mechanism. Can be used to group any UML element (e.g. use case, actors, classes, components and other packages. Commonly used for specifying the logical distribution of classes. A package does not necessarily translate into a physical sub-system. Name

Logical Distribution of Classes Higher level of abstraction over classes. Aids in administration and coordination of the development process. Contributes to the scalability of the system. Logical distribution of classes is inferred from the logical architecture of the system.

Packages and Class Diagrams Emphasize the logical structure of the system (High level view) c a b

Packages and Class Diagrams (cont.) Emphasize the interface between packages by showing relations and dependencies between public classes b a a.A b.C a.B

Packages and Class Diagrams (cont.) Add package information to class diagrams A D E F G C B

Packages and Class Diagrams (cont.) Add package information to class diagrams b a b.a a.A b.b.D b.b.E b.a.F b.a.G a.C a.B b.b

Tips Don’t try to use all the various notations. Don’t draw models for everything, concentrate on the key areas. Draw implementation models only when illustrating a particular implementation technique.