SlideShare una empresa de Scribd logo
1 de 44
OOAD
Class
Diagram
What is a Class Diagram?
• A Class Diagram is a diagram describing
the structure of a system
• shows the system's
• classes
• Attributes
• Operations (or methods),
• Relationships among the classes.
What is a Class Diagram?
• A class diagram depicts classes and their
interrelationships
• Used for describing structure and behavior in the
use cases
• Provide a conceptual model of the system in
terms of entities and their relationships
• Used for requirement capture, end-user
interaction
• Detailed class diagrams are used for developers
Essential Elements of a UML Class Diagram
• Class
• Attributes
• Operations
• Relationships
– Associations
– Generalization
– Realization
– Dependency
• Constraint Rules and Notes
Class
• Describes a set of objects having
similar:
– Attributes (status)
– Operations (behavior)
– Relationships with other classes
• Graphically, a class is rendered as
a rectangle, usually including its
name, attributes, and operations
in separate, designated
compartments.
Class Names
The name of the class is the only
required tag in the graphical
representation of a class. It always
appears in the top-most
compartment.
Class
Class Attributes and Operations
An attribute is a named property of a class that describes the object
being modeled.
In the class diagram, attributes appear in the second compartment
just below the name-compartment.
Attributes can be:
+ public
# protected
- private
Attributes are usually listed in the form:
attributeName : Type
Operations describe the class behavior and appear in the third
compartment.
Visibility and Access for attributes
and operations of a class
Class
Account_Name
- Customer_Name
- Balance
+addFunds( )
+withDraw( )
+transfer( )
Name
Attributes
Operations
Class Attributes and Operations
Class Attributes:
 The attribute type is shown after
the colon.
 Attributes map onto member
variables (data members) in code.
Class Operations (Methods):
 The return type of a method is
shown after the colon at the end of
the method signature.
 The type of method parameters
are shown after the colon following
the parameter name.
 Operations map onto class
methods in code
Operation (Method) Parameter Directionality
Parameter
direction
Description
in states that p1 and p2 are passed to
op1 by the caller.
They are both in parameters.
inout states that p3 is passed to op2 by
the caller and is then possibly
modified by op2 and is passed back
out.
p3 is an inout parameter.
out states that p6 is not set by the caller
but is modified by op3 and is passed
back out.
p6 is an out parameter.
Association
• In UML, object interconnections (logical or
physical), are modeled as relationships.
• 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.
• Example: “An Employee works for a
Company”
Employee Company
Association Relationships
If two classes in a model need to communicate with
each other, there must be link between them.
An association denotes that link.
InstructorStudent
Association Relationships
We can indicate the multiplicity of an association by
adding multiplicity adornments to the line denoting
the association.
The example indicates that a Student has one or more
Instructors:
InstructorStudent
1..*
Association Relationships
The example indicates that every Instructor has one or
more Students:
InstructorStudent
1..*
Association Relationships
We can also indicate the behavior of an object in an
association (i.e., the role of an object) using
rolenames.
InstructorStudent
1..*1..*
learns fromteaches
Association Relationships
We can also name the association.
TeamStudent
membership
1..* 1..*
Association Relationships
We can specify dual associations.
TeamStudent
member of
1..*
president of1 1..*
1..*
Associations
• Multiplicity
– the number of objects that participate in the association.
– Indicates whether or not an association is mandatory.
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
Multiplicity Indicators
Association Relationships
A class can have a self association.
LinkedListNode
next
previous
Aggregation
• A special form of association that models a
whole-part relationship between an aggregate
(the whole) and its parts.
• A directional association between objects.
• When an object ‘has-a’ another object, then
you have got an aggregation between them.
• Direction between them specified which
object contains the other object.
• It is also called ‘Has-a’ relationship.
Aggregation
 Class2 is part of Class1.
 Many instances (denoted by the *) of Class2
can be associated with Class1.
 Objects of Class1 and Class2 have separate
lifetimes.
Aggregation
• Note: If you delete the parent object, even
then the child object may exist. One object
can contain the other, but there is no
restriction that the composed object has to
exist in order to have existence of child object.
Aggregation
Whole Part
Car Door
2..*
Composition
• A strong form of aggregation
• In a more specific manner, a restricted
aggregation is called composition.
– The whole is the sole owner of its part.
• The part object may belong to only one whole
– The life time of the part is dependent upon the
whole.
• The composite must manage the creation and
destruction of its parts.
Composition
 Objects of Class2 live and die with
Class1.
 Class2 cannot stand by itself.
Composition
• A class contains students. A student cannot
exist without a class. There exists composition
between class and students.
Difference between aggregation
and composition
• Composition is more restrictive.
• When there is a composition between two objects,
the composed object cannot exist without the other
object.
• This restriction is not there in aggregation. Though
one object can contain the other object, there is no
condition that the composed object must exist.
• The existence of the composed object in aggregation
is entirely optional.
Difference between aggregation
and composition
• Example: A Library contains students and books.
Relationship between library and student is
aggregation.
• Relationship between library and book is
composition.
– A student can exist without a library and therefore it is
aggregation.
– A book cannot exist without a library and therefore its a
composition.
Generalization Relationship
o A generalization connects a
subclass to its superclass. It denotes
an inheritance of attributes and
behavior from the superclass to the
subclass and indicates a
specialization in the subclass of the
more general superclass.
o “is kind of” relationship.
Subtype2Subtype1
Supertype
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
Person
Student
Generalization Relationships
UML permits a class to inherit from multiple superclasses,
although some programming languages (e.g., Java) do not
permit multiple inheritance.
Student
TeachingAssistant
Employee
Generalization Relationships
 Inheritance is indicated by a solid line with a closed, 
unfilled arrowhead pointing at the super class
Generalization Relationships
An example of inheritance using tree notation
Packages
 UML provides an organizing element called
a package.
 Packages enable modelers to organize the
model's classifiers into namespaces, which is sort
of like folders in a filing system.
 Dividing a system into multiple packages
makes the system easier to understand,
especially if each package represents a specific
part of the system.
Drawing Packages
• There are two ways of drawing packages on
diagrams.
1. If the modeler decides to show the package's
members within the large rectangle, then all
those members need to be placed within the
rectangle.
Packages
Drawing Packages
2. If the modeler decides to show the package's
members outside the large rectangle then all
the members that will be shown on the
diagram need to be placed outside the
rectangle. To show what classifiers belong to
the package, a line is drawn from each
classifier to a circle that has a plus sign inside
the circle attached to the package
Packages
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 ArrayList
Constraint Rules and Notes
• Constraints and notes annotate among other things
associations, attributes, operations and classes.
• Constraints are semantic restrictions noted as
Boolean expressions.
– UML offers many pre-defined constraints.
id: long { value > 0 }
Customer
Order
*1
{ total < $50 }
may be
canceled
Constraint Note
What is a Object Diagram?
• Object diagrams represent an instance of a
class diagram.
• The purposes of object diagrams are similar to
class diagrams.
• The difference is that a class diagram
represents an abstract model consisting of
classes and their relationships. But an object
diagram represents an instance at a particular
moment which is concrete in nature.
Class and Objects

Más contenido relacionado

La actualidad más candente

5.state diagrams
5.state diagrams5.state diagrams
5.state diagrams
APU
 

La actualidad más candente (20)

Lecture04- Use Case Diagrams
Lecture04- Use Case DiagramsLecture04- Use Case Diagrams
Lecture04- Use Case Diagrams
 
Component Diagram
Component DiagramComponent Diagram
Component Diagram
 
Use case diagram
Use case diagramUse case diagram
Use case diagram
 
Activity Diagram
Activity DiagramActivity Diagram
Activity Diagram
 
Uml
UmlUml
Uml
 
Uml diagrams
Uml diagramsUml diagrams
Uml diagrams
 
Use Case Modeling
Use Case ModelingUse Case Modeling
Use Case Modeling
 
Deployment Diagram
Deployment DiagramDeployment Diagram
Deployment Diagram
 
Uml class Diagram
Uml class DiagramUml class Diagram
Uml class Diagram
 
Use Case Diagram
Use Case DiagramUse Case Diagram
Use Case Diagram
 
Class diagram presentation
Class diagram presentationClass diagram presentation
Class diagram presentation
 
Basic Behavioral Modeling
Basic Behavioral ModelingBasic Behavioral Modeling
Basic Behavioral Modeling
 
Uml class diagram and packages ppt for dot net
Uml class diagram and packages ppt for dot netUml class diagram and packages ppt for dot net
Uml class diagram and packages ppt for dot net
 
State Diagrams
State DiagramsState Diagrams
State Diagrams
 
Class Diagram
Class DiagramClass Diagram
Class Diagram
 
Uml in software engineering
Uml in software engineeringUml in software engineering
Uml in software engineering
 
Introduction to UML
Introduction to UMLIntroduction to UML
Introduction to UML
 
Class diagrams
Class diagramsClass diagrams
Class diagrams
 
Class diagram
Class diagramClass diagram
Class diagram
 
5.state diagrams
5.state diagrams5.state diagrams
5.state diagrams
 

Destacado

4.class diagramsusinguml
4.class diagramsusinguml4.class diagramsusinguml
4.class diagramsusinguml
APU
 
Object Modelling in Software Engineering
Object Modelling in Software EngineeringObject Modelling in Software Engineering
Object Modelling in Software Engineering
guest7fe55d5e
 
Unified Modelling Language
Unified Modelling LanguageUnified Modelling Language
Unified Modelling Language
R A Akerkar
 
Smart Gym System documentation
Smart Gym System documentationSmart Gym System documentation
Smart Gym System documentation
Tuvshinbayar Davaa
 
Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)
David Groff
 

Destacado (20)

Lecture-03 Introduction to UML
Lecture-03 Introduction to UMLLecture-03 Introduction to UML
Lecture-03 Introduction to UML
 
Class diagram
Class diagramClass diagram
Class diagram
 
Structured Vs, Object Oriented Analysis and Design
Structured Vs, Object Oriented Analysis and DesignStructured Vs, Object Oriented Analysis and Design
Structured Vs, Object Oriented Analysis and Design
 
4.class diagramsusinguml
4.class diagramsusinguml4.class diagramsusinguml
4.class diagramsusinguml
 
UML basic - Class Diagram
UML basic - Class DiagramUML basic - Class Diagram
UML basic - Class Diagram
 
Web 1.0, 2.0, 3.0
Web 1.0, 2.0, 3.0Web 1.0, 2.0, 3.0
Web 1.0, 2.0, 3.0
 
2 class use case
2 class use case2 class use case
2 class use case
 
Class diagram- UML diagram
Class diagram- UML diagramClass diagram- UML diagram
Class diagram- UML diagram
 
Object Modelling in Software Engineering
Object Modelling in Software EngineeringObject Modelling in Software Engineering
Object Modelling in Software Engineering
 
Difference between association, aggregation and composition
Difference between association, aggregation and compositionDifference between association, aggregation and composition
Difference between association, aggregation and composition
 
SE_Lec 07_UML CLASS DIAGRAM
SE_Lec 07_UML CLASS DIAGRAMSE_Lec 07_UML CLASS DIAGRAM
SE_Lec 07_UML CLASS DIAGRAM
 
Unified Modelling Language
Unified Modelling LanguageUnified Modelling Language
Unified Modelling Language
 
class diagram
class diagramclass diagram
class diagram
 
01 introduction to entity framework
01   introduction to entity framework01   introduction to entity framework
01 introduction to entity framework
 
Ooad sequence diagram lecture
Ooad sequence diagram lectureOoad sequence diagram lecture
Ooad sequence diagram lecture
 
Class diagram, use case and sequence diagram
Class diagram, use case and sequence diagramClass diagram, use case and sequence diagram
Class diagram, use case and sequence diagram
 
Smart Gym System documentation
Smart Gym System documentationSmart Gym System documentation
Smart Gym System documentation
 
Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)
 
Sequence diagram- UML diagram
Sequence diagram- UML diagramSequence diagram- UML diagram
Sequence diagram- UML diagram
 
Computer architecture and organization
Computer architecture and organizationComputer architecture and organization
Computer architecture and organization
 

Similar a Slide 5 Class Diagram

Relationships and their representation in a class diagram.pptx
Relationships and their representation in a class diagram.pptxRelationships and their representation in a class diagram.pptx
Relationships and their representation in a class diagram.pptx
nesarahmad37
 
Session13-Class Diagram (1).pdf
Session13-Class Diagram (1).pdfSession13-Class Diagram (1).pdf
Session13-Class Diagram (1).pdf
PeterTran514407
 
IBM OOAD Part1 Summary
IBM OOAD Part1 SummaryIBM OOAD Part1 Summary
IBM OOAD Part1 Summary
Haitham Raik
 
08 class and sequence diagrams
08   class and sequence diagrams08   class and sequence diagrams
08 class and sequence diagrams
kebsterz
 
Object and class relationships
Object and class relationshipsObject and class relationships
Object and class relationships
Pooja mittal
 

Similar a Slide 5 Class Diagram (20)

Relationships and their representation in a class diagram.pptx
Relationships and their representation in a class diagram.pptxRelationships and their representation in a class diagram.pptx
Relationships and their representation in a class diagram.pptx
 
06 class diagrams
06 class diagrams06 class diagrams
06 class diagrams
 
UML-class_diagram.ppt
UML-class_diagram.pptUML-class_diagram.ppt
UML-class_diagram.ppt
 
UML-class diagram for beginners to adance.ppt
UML-class diagram for beginners to adance.pptUML-class diagram for beginners to adance.ppt
UML-class diagram for beginners to adance.ppt
 
Software Testing and UML Lab
Software Testing and UML LabSoftware Testing and UML Lab
Software Testing and UML Lab
 
Session13-Class Diagram (1).pdf
Session13-Class Diagram (1).pdfSession13-Class Diagram (1).pdf
Session13-Class Diagram (1).pdf
 
210280107093_CLASS_DIAGRAM.pptx
210280107093_CLASS_DIAGRAM.pptx210280107093_CLASS_DIAGRAM.pptx
210280107093_CLASS_DIAGRAM.pptx
 
Advanced Structural Modeling
Advanced Structural ModelingAdvanced Structural Modeling
Advanced Structural Modeling
 
IBM OOAD Part1 Summary
IBM OOAD Part1 SummaryIBM OOAD Part1 Summary
IBM OOAD Part1 Summary
 
Different Types Diagrams
Different Types Diagrams  Different Types Diagrams
Different Types Diagrams
 
Introduction to UML
Introduction to UMLIntroduction to UML
Introduction to UML
 
Fundamentals of Software Engineering
Fundamentals of Software Engineering Fundamentals of Software Engineering
Fundamentals of Software Engineering
 
UML Training for Business Analysts
UML Training for Business AnalystsUML Training for Business Analysts
UML Training for Business Analysts
 
Lecture 4-oop class diagram
Lecture 4-oop class diagramLecture 4-oop class diagram
Lecture 4-oop class diagram
 
Claas diagram
Claas diagramClaas diagram
Claas diagram
 
Claas diagram
Claas diagramClaas diagram
Claas diagram
 
classdiagram.pptx
classdiagram.pptxclassdiagram.pptx
classdiagram.pptx
 
Ooad lab manual
Ooad  lab manualOoad  lab manual
Ooad lab manual
 
08 class and sequence diagrams
08   class and sequence diagrams08   class and sequence diagrams
08 class and sequence diagrams
 
Object and class relationships
Object and class relationshipsObject and class relationships
Object and class relationships
 

Último

Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
ZurliaSoop
 

Último (20)

2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx
2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx
2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx
 
Key note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdfKey note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdf
 
This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.
 
Mehran University Newsletter Vol-X, Issue-I, 2024
Mehran University Newsletter Vol-X, Issue-I, 2024Mehran University Newsletter Vol-X, Issue-I, 2024
Mehran University Newsletter Vol-X, Issue-I, 2024
 
Holdier Curriculum Vitae (April 2024).pdf
Holdier Curriculum Vitae (April 2024).pdfHoldier Curriculum Vitae (April 2024).pdf
Holdier Curriculum Vitae (April 2024).pdf
 
How to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptxHow to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptx
 
Python Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docxPython Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docx
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibit
 
Google Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptxGoogle Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptx
 
Jamworks pilot and AI at Jisc (20/03/2024)
Jamworks pilot and AI at Jisc (20/03/2024)Jamworks pilot and AI at Jisc (20/03/2024)
Jamworks pilot and AI at Jisc (20/03/2024)
 
SOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning PresentationSOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning Presentation
 
Wellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptxWellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptx
 
Graduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - EnglishGraduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - English
 
Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)
 
Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structure
 
ICT role in 21st century education and it's challenges.
ICT role in 21st century education and it's challenges.ICT role in 21st century education and it's challenges.
ICT role in 21st century education and it's challenges.
 
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
 
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptxOn_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
 
Application orientated numerical on hev.ppt
Application orientated numerical on hev.pptApplication orientated numerical on hev.ppt
Application orientated numerical on hev.ppt
 
Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Hongkong ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
 

Slide 5 Class Diagram

  • 2. What is a Class Diagram? • A Class Diagram is a diagram describing the structure of a system • shows the system's • classes • Attributes • Operations (or methods), • Relationships among the classes.
  • 3. What is a Class Diagram? • A class diagram depicts classes and their interrelationships • Used for describing structure and behavior in the use cases • Provide a conceptual model of the system in terms of entities and their relationships • Used for requirement capture, end-user interaction • Detailed class diagrams are used for developers
  • 4. Essential Elements of a UML Class Diagram • Class • Attributes • Operations • Relationships – Associations – Generalization – Realization – Dependency • Constraint Rules and Notes
  • 5. Class • Describes a set of objects having similar: – Attributes (status) – Operations (behavior) – Relationships with other classes • Graphically, a class is rendered as a rectangle, usually including its name, attributes, and operations in separate, designated compartments.
  • 6. Class Names The name of the class is the only required tag in the graphical representation of a class. It always appears in the top-most compartment.
  • 8. Class Attributes and Operations An attribute is a named property of a class that describes the object being modeled. In the class diagram, attributes appear in the second compartment just below the name-compartment. Attributes can be: + public # protected - private Attributes are usually listed in the form: attributeName : Type Operations describe the class behavior and appear in the third compartment.
  • 9. Visibility and Access for attributes and operations of a class
  • 10. Class Account_Name - Customer_Name - Balance +addFunds( ) +withDraw( ) +transfer( ) Name Attributes Operations
  • 11. Class Attributes and Operations Class Attributes:  The attribute type is shown after the colon.  Attributes map onto member variables (data members) in code. Class Operations (Methods):  The return type of a method is shown after the colon at the end of the method signature.  The type of method parameters are shown after the colon following the parameter name.  Operations map onto class methods in code
  • 12. Operation (Method) Parameter Directionality Parameter direction Description in states that p1 and p2 are passed to op1 by the caller. They are both in parameters. inout states that p3 is passed to op2 by the caller and is then possibly modified by op2 and is passed back out. p3 is an inout parameter. out states that p6 is not set by the caller but is modified by op3 and is passed back out. p6 is an out parameter.
  • 13. Association • In UML, object interconnections (logical or physical), are modeled as relationships. • 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. • Example: “An Employee works for a Company” Employee Company
  • 14. Association Relationships If two classes in a model need to communicate with each other, there must be link between them. An association denotes that link. InstructorStudent
  • 15. Association Relationships We can indicate the multiplicity of an association by adding multiplicity adornments to the line denoting the association. The example indicates that a Student has one or more Instructors: InstructorStudent 1..*
  • 16. Association Relationships The example indicates that every Instructor has one or more Students: InstructorStudent 1..*
  • 17. Association Relationships We can also indicate the behavior of an object in an association (i.e., the role of an object) using rolenames. InstructorStudent 1..*1..* learns fromteaches
  • 18. Association Relationships We can also name the association. TeamStudent membership 1..* 1..*
  • 19. Association Relationships We can specify dual associations. TeamStudent member of 1..* president of1 1..* 1..*
  • 20. Associations • Multiplicity – the number of objects that participate in the association. – Indicates whether or not an association is mandatory. 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 Multiplicity Indicators
  • 21. Association Relationships A class can have a self association. LinkedListNode next previous
  • 22. Aggregation • A special form of association that models a whole-part relationship between an aggregate (the whole) and its parts. • A directional association between objects. • When an object ‘has-a’ another object, then you have got an aggregation between them. • Direction between them specified which object contains the other object. • It is also called ‘Has-a’ relationship.
  • 23. Aggregation  Class2 is part of Class1.  Many instances (denoted by the *) of Class2 can be associated with Class1.  Objects of Class1 and Class2 have separate lifetimes.
  • 24. Aggregation • Note: If you delete the parent object, even then the child object may exist. One object can contain the other, but there is no restriction that the composed object has to exist in order to have existence of child object.
  • 26. Composition • A strong form of aggregation • In a more specific manner, a restricted aggregation is called composition. – The whole is the sole owner of its part. • The part object may belong to only one whole – The life time of the part is dependent upon the whole. • The composite must manage the creation and destruction of its parts.
  • 27. Composition  Objects of Class2 live and die with Class1.  Class2 cannot stand by itself.
  • 28. Composition • A class contains students. A student cannot exist without a class. There exists composition between class and students.
  • 29. Difference between aggregation and composition • Composition is more restrictive. • When there is a composition between two objects, the composed object cannot exist without the other object. • This restriction is not there in aggregation. Though one object can contain the other object, there is no condition that the composed object must exist. • The existence of the composed object in aggregation is entirely optional.
  • 30. Difference between aggregation and composition • Example: A Library contains students and books. Relationship between library and student is aggregation. • Relationship between library and book is composition. – A student can exist without a library and therefore it is aggregation. – A book cannot exist without a library and therefore its a composition.
  • 31. Generalization Relationship o A generalization connects a subclass to its superclass. It denotes an inheritance of attributes and behavior from the superclass to the subclass and indicates a specialization in the subclass of the more general superclass. o “is kind of” relationship. Subtype2Subtype1 Supertype
  • 32. 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 Person Student
  • 33. Generalization Relationships UML permits a class to inherit from multiple superclasses, although some programming languages (e.g., Java) do not permit multiple inheritance. Student TeachingAssistant Employee
  • 36. Packages  UML provides an organizing element called a package.  Packages enable modelers to organize the model's classifiers into namespaces, which is sort of like folders in a filing system.  Dividing a system into multiple packages makes the system easier to understand, especially if each package represents a specific part of the system.
  • 37. Drawing Packages • There are two ways of drawing packages on diagrams. 1. If the modeler decides to show the package's members within the large rectangle, then all those members need to be placed within the rectangle.
  • 39. Drawing Packages 2. If the modeler decides to show the package's members outside the large rectangle then all the members that will be shown on the diagram need to be placed outside the rectangle. To show what classifiers belong to the package, a line is drawn from each classifier to a circle that has a plus sign inside the circle attached to the package
  • 41. 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 ArrayList
  • 42. Constraint Rules and Notes • Constraints and notes annotate among other things associations, attributes, operations and classes. • Constraints are semantic restrictions noted as Boolean expressions. – UML offers many pre-defined constraints. id: long { value > 0 } Customer Order *1 { total < $50 } may be canceled Constraint Note
  • 43. What is a Object Diagram? • Object diagrams represent an instance of a class diagram. • The purposes of object diagrams are similar to class diagrams. • The difference is that a class diagram represents an abstract model consisting of classes and their relationships. But an object diagram represents an instance at a particular moment which is concrete in nature.

Notas del editor

  1. Syntax: visibility name (dir parameterName : type = default value, ... ) : returnType Parameter directions: in, out, inout or return Only name is mandatory in Analysis