SlideShare a Scribd company logo
Object Modeling

          OOAD
       MCA 405 C (N2)



           Amandeep S. Patti   1
Objects and Classes
   Object can be a concept, abstraction or
    thing with crisp boundaries and meaning
    for the problem at hand.
   They promote understanding of the real
    world and provide a practical basis for
    computer implementations.



                   Amandeep S. Patti     2
Objects and Classes
   A class describes a group of objects with
    similar properties (attributes), common
    behaviour (operations), common relations
    to other objects and common semantics.
   The objects in a class share a common
    semantic purpose.



                   Amandeep S. Patti       3
Object Diagram
   Object diagram provide a formal graphic
    notation for modeling objects, classes and
    their relationships to one another.
   Object diagrams are useful both for
    abstract modeling and for designing actual
    programs.



                    Amandeep S. Patti       4
Object Diagram
   There are two types of object diagrams.
       A class diagram is a schema, pattern or
        template for describing many possible
        instances of data. A class diagram describes
        object classes.
       An instance diagram describes how a
        particular set of objects relate to each other.
        An instance diagram describes object
        instances.

                        Amandeep S. Patti           5
Attributes
   An attribute is a data value held by the objects in
    a class.
   Each attribute has a value for each object
    instance.
   Different object instances may have same or
    different values for a given attribute.
   Each attribute name is unique within a class.
   An attribute should be a pure data value, not an
    object.

                       Amandeep S. Patti            6
Operations and Methods
Operations
 An operation is a function or transformation that

  may be applied to or by objects in a class.
 Each operation has a target object as an implicit

  argument. The behaviour of the operation
  depends on the class of its target.
 The same operation may apply to many different

  classes.

                    Amandeep S. Patti           7
Operations and Methods
   A method is the implementation of the operation
    for a class.
   An operation may have arguments in addition to
    its target object. Such arguments parameterize
    the operation but do not affect the choice of
    method.
   The method depends only on the class of the
    target object.
   When an operation has methods on several
    classes, it is important that the methods all have
    the same signature.
                       Amandeep S. Patti            8
Notations for Class Diagram
                                         Place the name of the
        Class Name
                                          class in the first
Attribute: Type = Value                   partition      (centered,
                                          bolded, & capitalized),
                                          list the attributes in the
                                          second partition, and
Operation(arg_List): return type
                                          write operations into
                                          the third.


                             Amandeep S. Patti                   9
Links and Associations
   Represent static relationship between
    classes.
   A link is a physical or conceptual
    connection between object instances.
   An association describes a group of links
    with common structure and common
    semantics.

                   Amandeep S. Patti      10
Links and Associations
   All the links in an association connect
    objects from the same classes.
   Both often appear as verbs in a problem
    statement.
   Associations are inherently bi-directional.
   Associations are often implemented in
    programming languages as pointers from
    one object to another.

                    Amandeep S. Patti       11
Links and Associations
1    No more than one                   Company
0..1 Zero or One                             1
*    Many
0..* Zero or Many                            1..*
1..* One or Many                         Person




                    Amandeep S. Patti               12
Multiplicity
   It specifies how many instances of one
    class may relate to a single instance of an
    associated class.
   It constrains the number of related objects.
   It is generally described as being “one” or
    “many”, but it is a subset of non-negative
    integers.
   It depends on assumptions and how you
    define the boundaries of a problem.
                     Amandeep S. Patti       13
Class Name
    Multiplicity              Attribute: Type = Value

                              Operation(arg_List): return type

                                        *       {Constraints}   *
For    example,     one
company will have one or
more employees, but                     1..*                    1
each employee works for
                                            Class Name
one company only.             Attribute: Type = Value

                              Operation(arg_List): return type



                    Amandeep S. Patti                               14
Link Attributes
   A link attribute is a property of the links in
    an association.

                    Accessible by
        File                               User


                    Access permission




                       Amandeep S. Patti          15
Role Names
   A role is an end of an association.
   A binary association has two roles, each of which
    may have a role name.
   A role is a name that uniquely identifies one end
    of an association.
   Role names are necessary for associations
    between two objects of same class.
                 Employee        Employe
      Person           Works-for r         Company

                       Amandeep S. Patti             16
Ordering
   The ordering is an inherent part of the
    association. An ordered set of objects on
    the “many” end of an association is
    indicated by writing “{ordered}” next to the
    multiplicity dot for the role.
   This is a special kind of constraint.
                {Ordered}
       Window                             Screen
                    Visible-on


                      Amandeep S. Patti            17
Qualification
   A qualified association relates two classes
    and a qualifier.
   One to many and many to many
    associations may be qualified.
   The qualifier is a special attribute that
    reduces the effective multiplicity of an
    association.


                    Amandeep S. Patti       18
Qualification
   The qualifier distinguishes among the set
    of objects at the many end of an
    association.
   A qualified association can also be
    considered as ternary association.
    Directory   File                       File
                name




                       Amandeep S. Patti          19
Aggregation
   Aggregation is the “part-whole” or “a-part-of”
    relationship in which objects representing the
    components of something are associated with
    an object representing the entire assembly.
   The aggregate is semantically an extended
    object that is treated as a unit in many
    operations, although physically it is made of
    several objects.

                     Amandeep S. Patti         20
Aggregation
   Aggregation is inherently transitive; An
    aggregate has parts, which may in turn
    have parts.
   Many aggregate operations operate on
    both direct and indirect parts.
   Aggregation can be fixed, variable or
    recursive.

                   Amandeep S. Patti     21
Types of Aggregation
   A fixed aggregate has a fixed structure; The
    types and number of subparts are predefined.
   A variable aggregate has a finite number of
    levels, but the number of parts may vary.
   A recursive aggregate contains directly or
    indirectly, an instance of the same kind of
    aggregate; the no. of potential levels is
    unlimited.

                    Amandeep S. Patti        22
Propagation of Operations
   Propagation is the automatic application of an
    operation to a network of objects when the
    operation is applied to some starting object.
   The propagation behaviour is bound to an
    association, direction and operation.
   Propagation is indicated on object models with a
    small arrow & operation name next to the
    affected association. The arrow indicates the
    direction of propagation.
                      Amandeep S. Patti          23
Generalization
   It is the relationship between a class and
    one or more refined versions of it. The
    class being refined is called the superclass
    and each refined version is called
    subclass.
   It is sometimes called the “is-a” relationship
    because each instance of a subclass is an
    instance of superclass as well.
                     Amandeep S. Patti         24
Generalization
   The notation for generalization is a triangle
    connecting a superclass to its subclasses.
    The superclass is connected by a line to
    the apex of the triangle and the subclasses
    are connected by the line to a horizontal
    bar attached to the base of the triangle.



                     Amandeep S. Patti        25
Generalization                             Figure
                                             Color
                                             Center position
   “Dimensionality”        is               Move
    discriminator.                           select
   It is an attribute of
    enumeration type that                             dimensionality

    indicates which property
                                     One Dim                  Two Dim
    of an object is being
                                  Orientation          Orientation
    abstracted     by        a
                                                       Fill type
    particular generalization
                                  Scale                Scale
    relationship.
                                                       fill


                         Amandeep S. Patti                           26
Generalization, Inheritance and
     Specialization
   Generalization is used to refer to the
    relationship among classes, while inheritance
    refers to the mechanism of sharing attributes
    and operations using the generalization
    relationship.
   Generalization and specialization are two
    different viewpoints of the same relationship,
    viewed from superclass or from the subclass.

                     Amandeep S. Patti         27
Aggregation V/s Generalization
   Aggregation relates instances. Two distinct
    objects are involved; One of them is part of
    other whereas generalization relates
    classes and is a way of structuring the
    description of a single object. Both super
    class and subclass refer to properties of a
    single object.


                    Amandeep S. Patti        28
Aggregation V/s Generalization
   An aggregation tree is composed of object
    instances that are all part of a composite
    object; A generalization tree is composed
    of classes that describe an object.
   Aggregation is often called “a-part-of”
    relationship (sometime called “and-relationship”);
    Generalization is often called “a-kind of” or
    “is-a” relationship (sometime called “or-
    relationship”).

                       Amandeep S. Patti           29
Aggregation v/s Association
   Aggregation is a special form of association,
    not an independent concept.
   Aggregation adds semantic connotations in
    certain cases. If two objects are tightly
    bound by a part-whole relationship, it is an
    aggregation.
   If two objects are independent, and they are
    linked, it is an association.

                     Amandeep S. Patti       30
Abstract class
   An incomplete superclass that defines common
    features to several classes.
   Not instantiated.
   Frequently used to define methods to be
    inherited by subclasses.
   It can define the protocol for an operation
    (abstract operation) without supplying a
    corresponding method, for which each subclass
    must provide its own implementation.

                     Amandeep S. Patti        31
Concrete class
   Is a complete class.
   Describes a concept completely.
   Is intended to be instantiated.
   It may have abstract subclasses (but they in
    turn must have concrete descendants).
   Only concrete classes may be leaf classes
    in the inheritance tree.


                    Amandeep S. Patti        32
Generalization as Extension and
    Restriction
   In generalization, an instance of a class is an
    instance of the class. Therefore all ancestor class
    features must apply to the subclass instances. A
    descendent class cannot omit or suppress an
    ancestor attribute because then it could not truly be
    an ancestor instance. Similarly operations on an
    ancestor class must apply to all descendent classes.
    A subclass may re-implement an operation for
    reasons of efficiency but cannot change the external
    protocol.
   Adding features is called Extension.
   Constraining ancestor attributes is called Restriction.
                         Amandeep S. Patti             33
Overriding Operations
   The mechanism by which a child class can
    provide an alternative implementation of a
    method currently provided by a parent class.
   Overriding for extension: the new operation is the
    same as the inherited operation, except it adds
    some behaviour, usually affecting new attributes
    of the subclass.
   Overriding for restriction: The new operation
    restricts the protocol, such as tightening the
    types of arguments.
                       Amandeep S. Patti           34
Overriding Operations
   Overriding for optimization: An implementation
    can take advantage of the constraints imposed
    by a restriction to improve the code for an
    operation, and it is valid use of overriding.
   Overriding for convenience: A common practice
    in developing new classes is to look for a class
    similar to what is desired. The new class is made
    a subclass of the existing class and overrides the
    methods that are inconvenient. This ad hoc use
    of inheritance is semantically wrong.

                      Amandeep S. Patti            35
Multiple Inheritance
   A class may inherits features from more than one
    superclass. Such class is called a join class.
   A feature from the same ancestor class found
    along more than one path is inherited only once.
   The advantage of multiple inheritance is greater
    power in specifying classes and an increased
    opportunity for reuse. It brings object modeling
    closer to the way people thinks.
   The disadvantage is a loss of conceptual and
    implementation simplicity.
                      Amandeep S. Patti          36
Workarounds
                        Employee



            Employee                               Employee
            Payroll                                Pension




Hourly      Salaried   Exempt                  Vested        Unvested
Employee    Employee   Employee                Employee      Employee

           Multiple Inheritance Using delegation

                           Amandeep S. Patti                        37
Workarounds
                                                     Employee
           Employee
                                                     Pension

 Pay Status
                                                            Pension Status

Hourly        Salaried   Exempt                  Vested        Unvested
Employee      Employee   Employee                Employee      Employee


   Multiple Inheritance using inheritance & delegation




                             Amandeep S. Patti                        38
Metadata
   Data about data.
      Models are inherently metadata.

      Parts catalogs, blue-prints, dictionaries etc.

   Patterns and Metadata




                           Amandeep S. Patti            39
Constraints
   Constraints are functional relationships between
    entities of an object model. The term entity
    includes objects, classes, attributes, links and
    associations.
   A constraint restricts the values that entities can
    assume.
   A good object model captures many constraints
    through its structure.
   Object modeling notation for constraints is as follows: Constraints are
    delimited by braces and positioned near the constrained entity. A
    dotted line connects multiple constrained entities.

                               Amandeep S. Patti                      40
Constraints
  Employe                      Window
  e                        Length
     Salary                width
{Salary <= boss.Salary}   {length > width}

           Constraints on
           objects

                                    {ordered}
 Country         Office                         Person

         Constraints on association
         links
                          Amandeep S. Patti              41
Derived Objects, Links and Attributes
   A derived object is defined as a function of
    one or more objects, which in turn may be
    derived.
   The notation for derived entity is a slash or
    diagonal line (on the corner of a class box, or
    an association line, or in front of an attribute).
Machine                 Assembly                 Part


              offset                    offset   Offset
                         Amandeep S. Patti                42
Homomorphism
                                       Maps                   Contains
     Contains
CatalogItem                                       Item
Model number                                  Serial number
                      Describes

{Item1 contains item2 => item1.model contains item2.model}

     Homomorphism for a parts
     catalog



                        Amandeep S. Patti                          43

More Related Content

PPTX
Sequence diagram
PPT
Collaboration Diagram
PPT
Object Oriented Design
PPTX
object oriented methodologies
PDF
Collaboration diagram- UML diagram
PDF
Sequence diagrams
PPT
Object and class relationships
PDF
Domain specific Software Architecture
Sequence diagram
Collaboration Diagram
Object Oriented Design
object oriented methodologies
Collaboration diagram- UML diagram
Sequence diagrams
Object and class relationships
Domain specific Software Architecture

What's hot (20)

PPT
PPT
System Models in Software Engineering SE7
PPT
Object Oriented Design in Software Engineering SE12
PPTX
Object modeling
PPTX
Uml Presentation
PPT
PDF
CS6502 OOAD - Question Bank and Answer
PDF
Dbms Notes Lecture 9 : Specialization, Generalization and Aggregation
PPT
Software Design Patterns
PDF
Domain Modeling
PPTX
Ado.Net Tutorial
PPTX
Overview of UML Diagrams
PPTX
Software Engineering Practice
PDF
Gof design pattern
PPTX
Importance & Principles of Modeling from UML Designing
PPTX
JAVA AWT
PPT
Unit 1( modelling concepts & class modeling)
PPTX
Object oriented methodologies
PPTX
Congestion control
System Models in Software Engineering SE7
Object Oriented Design in Software Engineering SE12
Object modeling
Uml Presentation
CS6502 OOAD - Question Bank and Answer
Dbms Notes Lecture 9 : Specialization, Generalization and Aggregation
Software Design Patterns
Domain Modeling
Ado.Net Tutorial
Overview of UML Diagrams
Software Engineering Practice
Gof design pattern
Importance & Principles of Modeling from UML Designing
JAVA AWT
Unit 1( modelling concepts & class modeling)
Object oriented methodologies
Congestion control
Ad

Similar to Object modeling (20)

PPT
objectmodeling-121201024636-phpapp01.ppt
PPT
Object modeling
PPT
UML-class diagram for beginners to adance.ppt
PPT
cse 355 UML class diagram software engineering.ppt
PPT
UML-class_diagram.ppt
PPT
UML-class_diagram.ppt diagrams ppt download
PPTX
Domain model Refinement
PPT
PPT
08 class and sequence diagrams
PPT
Ooad ch 4
PDF
Lecture05-Structural Modeling for students.pdf
PPT
Slide 5 Class Diagram
PDF
Software Engineering GTU Ch.4 Solution exam
PDF
Software Testing and UML Lab
DOCX
Structural ModelingDr. Ardeshir BadrObjectives• .docx
PPT
Uml - An Overview
PPT
Chapter3
PPTX
Relationships and their representation in a class diagram.pptx
PPT
Unit 2(advanced class modeling & state diagram)
objectmodeling-121201024636-phpapp01.ppt
Object modeling
UML-class diagram for beginners to adance.ppt
cse 355 UML class diagram software engineering.ppt
UML-class_diagram.ppt
UML-class_diagram.ppt diagrams ppt download
Domain model Refinement
08 class and sequence diagrams
Ooad ch 4
Lecture05-Structural Modeling for students.pdf
Slide 5 Class Diagram
Software Engineering GTU Ch.4 Solution exam
Software Testing and UML Lab
Structural ModelingDr. Ardeshir BadrObjectives• .docx
Uml - An Overview
Chapter3
Relationships and their representation in a class diagram.pptx
Unit 2(advanced class modeling & state diagram)
Ad

More from Anand Grewal (12)

PPT
distributed dbms
PPT
Transaction concurrency control
PPT
Object analysis and design
PPT
O ops concepts
PPT
System design
PPTX
Presentation12
PPTX
Presentation1
PPTX
Event handling
PPTX
PPTX
PPTX
Pptemail
PPTX
Presentation on dns
distributed dbms
Transaction concurrency control
Object analysis and design
O ops concepts
System design
Presentation12
Presentation1
Event handling
Pptemail
Presentation on dns

Recently uploaded (20)

PDF
O5-L3 Freight Transport Ops (International) V1.pdf
PDF
Anesthesia in Laparoscopic Surgery in India
PDF
TR - Agricultural Crops Production NC III.pdf
PDF
FourierSeries-QuestionsWithAnswers(Part-A).pdf
PDF
Microbial disease of the cardiovascular and lymphatic systems
PDF
Computing-Curriculum for Schools in Ghana
PDF
01-Introduction-to-Information-Management.pdf
PDF
Pre independence Education in Inndia.pdf
PDF
Saundersa Comprehensive Review for the NCLEX-RN Examination.pdf
PDF
The Lost Whites of Pakistan by Jahanzaib Mughal.pdf
PPTX
PPT- ENG7_QUARTER1_LESSON1_WEEK1. IMAGERY -DESCRIPTIONS pptx.pptx
PPTX
Renaissance Architecture: A Journey from Faith to Humanism
PPTX
master seminar digital applications in india
PPTX
Cell Structure & Organelles in detailed.
PPTX
GDM (1) (1).pptx small presentation for students
PDF
BÀI TẬP BỔ TRỢ 4 KỸ NĂNG TIẾNG ANH 9 GLOBAL SUCCESS - CẢ NĂM - BÁM SÁT FORM Đ...
PPTX
BOWEL ELIMINATION FACTORS AFFECTING AND TYPES
PDF
Classroom Observation Tools for Teachers
PDF
ANTIBIOTICS.pptx.pdf………………… xxxxxxxxxxxxx
PPTX
Microbial diseases, their pathogenesis and prophylaxis
O5-L3 Freight Transport Ops (International) V1.pdf
Anesthesia in Laparoscopic Surgery in India
TR - Agricultural Crops Production NC III.pdf
FourierSeries-QuestionsWithAnswers(Part-A).pdf
Microbial disease of the cardiovascular and lymphatic systems
Computing-Curriculum for Schools in Ghana
01-Introduction-to-Information-Management.pdf
Pre independence Education in Inndia.pdf
Saundersa Comprehensive Review for the NCLEX-RN Examination.pdf
The Lost Whites of Pakistan by Jahanzaib Mughal.pdf
PPT- ENG7_QUARTER1_LESSON1_WEEK1. IMAGERY -DESCRIPTIONS pptx.pptx
Renaissance Architecture: A Journey from Faith to Humanism
master seminar digital applications in india
Cell Structure & Organelles in detailed.
GDM (1) (1).pptx small presentation for students
BÀI TẬP BỔ TRỢ 4 KỸ NĂNG TIẾNG ANH 9 GLOBAL SUCCESS - CẢ NĂM - BÁM SÁT FORM Đ...
BOWEL ELIMINATION FACTORS AFFECTING AND TYPES
Classroom Observation Tools for Teachers
ANTIBIOTICS.pptx.pdf………………… xxxxxxxxxxxxx
Microbial diseases, their pathogenesis and prophylaxis

Object modeling

  • 1. Object Modeling OOAD MCA 405 C (N2) Amandeep S. Patti 1
  • 2. Objects and Classes  Object can be a concept, abstraction or thing with crisp boundaries and meaning for the problem at hand.  They promote understanding of the real world and provide a practical basis for computer implementations. Amandeep S. Patti 2
  • 3. Objects and Classes  A class describes a group of objects with similar properties (attributes), common behaviour (operations), common relations to other objects and common semantics.  The objects in a class share a common semantic purpose. Amandeep S. Patti 3
  • 4. Object Diagram  Object diagram provide a formal graphic notation for modeling objects, classes and their relationships to one another.  Object diagrams are useful both for abstract modeling and for designing actual programs. Amandeep S. Patti 4
  • 5. Object Diagram  There are two types of object diagrams.  A class diagram is a schema, pattern or template for describing many possible instances of data. A class diagram describes object classes.  An instance diagram describes how a particular set of objects relate to each other. An instance diagram describes object instances. Amandeep S. Patti 5
  • 6. Attributes  An attribute is a data value held by the objects in a class.  Each attribute has a value for each object instance.  Different object instances may have same or different values for a given attribute.  Each attribute name is unique within a class.  An attribute should be a pure data value, not an object. Amandeep S. Patti 6
  • 7. Operations and Methods Operations  An operation is a function or transformation that may be applied to or by objects in a class.  Each operation has a target object as an implicit argument. The behaviour of the operation depends on the class of its target.  The same operation may apply to many different classes. Amandeep S. Patti 7
  • 8. Operations and Methods  A method is the implementation of the operation for a class.  An operation may have arguments in addition to its target object. Such arguments parameterize the operation but do not affect the choice of method.  The method depends only on the class of the target object.  When an operation has methods on several classes, it is important that the methods all have the same signature. Amandeep S. Patti 8
  • 9. Notations for Class Diagram  Place the name of the Class Name class in the first Attribute: Type = Value partition (centered, bolded, & capitalized), list the attributes in the second partition, and Operation(arg_List): return type write operations into the third. Amandeep S. Patti 9
  • 10. Links and Associations  Represent static relationship between classes.  A link is a physical or conceptual connection between object instances.  An association describes a group of links with common structure and common semantics. Amandeep S. Patti 10
  • 11. Links and Associations  All the links in an association connect objects from the same classes.  Both often appear as verbs in a problem statement.  Associations are inherently bi-directional.  Associations are often implemented in programming languages as pointers from one object to another. Amandeep S. Patti 11
  • 12. Links and Associations 1 No more than one Company 0..1 Zero or One 1 * Many 0..* Zero or Many 1..* 1..* One or Many Person Amandeep S. Patti 12
  • 13. Multiplicity  It specifies how many instances of one class may relate to a single instance of an associated class.  It constrains the number of related objects.  It is generally described as being “one” or “many”, but it is a subset of non-negative integers.  It depends on assumptions and how you define the boundaries of a problem. Amandeep S. Patti 13
  • 14. Class Name Multiplicity Attribute: Type = Value Operation(arg_List): return type * {Constraints} * For example, one company will have one or more employees, but 1..* 1 each employee works for Class Name one company only. Attribute: Type = Value Operation(arg_List): return type Amandeep S. Patti 14
  • 15. Link Attributes  A link attribute is a property of the links in an association. Accessible by File User Access permission Amandeep S. Patti 15
  • 16. Role Names  A role is an end of an association.  A binary association has two roles, each of which may have a role name.  A role is a name that uniquely identifies one end of an association.  Role names are necessary for associations between two objects of same class. Employee Employe Person Works-for r Company Amandeep S. Patti 16
  • 17. Ordering  The ordering is an inherent part of the association. An ordered set of objects on the “many” end of an association is indicated by writing “{ordered}” next to the multiplicity dot for the role.  This is a special kind of constraint. {Ordered} Window Screen Visible-on Amandeep S. Patti 17
  • 18. Qualification  A qualified association relates two classes and a qualifier.  One to many and many to many associations may be qualified.  The qualifier is a special attribute that reduces the effective multiplicity of an association. Amandeep S. Patti 18
  • 19. Qualification  The qualifier distinguishes among the set of objects at the many end of an association.  A qualified association can also be considered as ternary association. Directory File File name Amandeep S. Patti 19
  • 20. Aggregation  Aggregation is the “part-whole” or “a-part-of” relationship in which objects representing the components of something are associated with an object representing the entire assembly.  The aggregate is semantically an extended object that is treated as a unit in many operations, although physically it is made of several objects. Amandeep S. Patti 20
  • 21. Aggregation  Aggregation is inherently transitive; An aggregate has parts, which may in turn have parts.  Many aggregate operations operate on both direct and indirect parts.  Aggregation can be fixed, variable or recursive. Amandeep S. Patti 21
  • 22. Types of Aggregation  A fixed aggregate has a fixed structure; The types and number of subparts are predefined.  A variable aggregate has a finite number of levels, but the number of parts may vary.  A recursive aggregate contains directly or indirectly, an instance of the same kind of aggregate; the no. of potential levels is unlimited. Amandeep S. Patti 22
  • 23. Propagation of Operations  Propagation is the automatic application of an operation to a network of objects when the operation is applied to some starting object.  The propagation behaviour is bound to an association, direction and operation.  Propagation is indicated on object models with a small arrow & operation name next to the affected association. The arrow indicates the direction of propagation. Amandeep S. Patti 23
  • 24. Generalization  It is the relationship between a class and one or more refined versions of it. The class being refined is called the superclass and each refined version is called subclass.  It is sometimes called the “is-a” relationship because each instance of a subclass is an instance of superclass as well. Amandeep S. Patti 24
  • 25. Generalization  The notation for generalization is a triangle connecting a superclass to its subclasses. The superclass is connected by a line to the apex of the triangle and the subclasses are connected by the line to a horizontal bar attached to the base of the triangle. Amandeep S. Patti 25
  • 26. Generalization Figure Color Center position  “Dimensionality” is Move discriminator. select  It is an attribute of enumeration type that dimensionality indicates which property One Dim Two Dim of an object is being Orientation Orientation abstracted by a Fill type particular generalization Scale Scale relationship. fill Amandeep S. Patti 26
  • 27. Generalization, Inheritance and Specialization  Generalization is used to refer to the relationship among classes, while inheritance refers to the mechanism of sharing attributes and operations using the generalization relationship.  Generalization and specialization are two different viewpoints of the same relationship, viewed from superclass or from the subclass. Amandeep S. Patti 27
  • 28. Aggregation V/s Generalization  Aggregation relates instances. Two distinct objects are involved; One of them is part of other whereas generalization relates classes and is a way of structuring the description of a single object. Both super class and subclass refer to properties of a single object. Amandeep S. Patti 28
  • 29. Aggregation V/s Generalization  An aggregation tree is composed of object instances that are all part of a composite object; A generalization tree is composed of classes that describe an object.  Aggregation is often called “a-part-of” relationship (sometime called “and-relationship”); Generalization is often called “a-kind of” or “is-a” relationship (sometime called “or- relationship”). Amandeep S. Patti 29
  • 30. Aggregation v/s Association  Aggregation is a special form of association, not an independent concept.  Aggregation adds semantic connotations in certain cases. If two objects are tightly bound by a part-whole relationship, it is an aggregation.  If two objects are independent, and they are linked, it is an association. Amandeep S. Patti 30
  • 31. Abstract class  An incomplete superclass that defines common features to several classes.  Not instantiated.  Frequently used to define methods to be inherited by subclasses.  It can define the protocol for an operation (abstract operation) without supplying a corresponding method, for which each subclass must provide its own implementation. Amandeep S. Patti 31
  • 32. Concrete class  Is a complete class.  Describes a concept completely.  Is intended to be instantiated.  It may have abstract subclasses (but they in turn must have concrete descendants).  Only concrete classes may be leaf classes in the inheritance tree. Amandeep S. Patti 32
  • 33. Generalization as Extension and Restriction  In generalization, an instance of a class is an instance of the class. Therefore all ancestor class features must apply to the subclass instances. A descendent class cannot omit or suppress an ancestor attribute because then it could not truly be an ancestor instance. Similarly operations on an ancestor class must apply to all descendent classes. A subclass may re-implement an operation for reasons of efficiency but cannot change the external protocol.  Adding features is called Extension.  Constraining ancestor attributes is called Restriction. Amandeep S. Patti 33
  • 34. Overriding Operations  The mechanism by which a child class can provide an alternative implementation of a method currently provided by a parent class.  Overriding for extension: the new operation is the same as the inherited operation, except it adds some behaviour, usually affecting new attributes of the subclass.  Overriding for restriction: The new operation restricts the protocol, such as tightening the types of arguments. Amandeep S. Patti 34
  • 35. Overriding Operations  Overriding for optimization: An implementation can take advantage of the constraints imposed by a restriction to improve the code for an operation, and it is valid use of overriding.  Overriding for convenience: A common practice in developing new classes is to look for a class similar to what is desired. The new class is made a subclass of the existing class and overrides the methods that are inconvenient. This ad hoc use of inheritance is semantically wrong. Amandeep S. Patti 35
  • 36. Multiple Inheritance  A class may inherits features from more than one superclass. Such class is called a join class.  A feature from the same ancestor class found along more than one path is inherited only once.  The advantage of multiple inheritance is greater power in specifying classes and an increased opportunity for reuse. It brings object modeling closer to the way people thinks.  The disadvantage is a loss of conceptual and implementation simplicity. Amandeep S. Patti 36
  • 37. Workarounds Employee Employee Employee Payroll Pension Hourly Salaried Exempt Vested Unvested Employee Employee Employee Employee Employee Multiple Inheritance Using delegation Amandeep S. Patti 37
  • 38. Workarounds Employee Employee Pension Pay Status Pension Status Hourly Salaried Exempt Vested Unvested Employee Employee Employee Employee Employee Multiple Inheritance using inheritance & delegation Amandeep S. Patti 38
  • 39. Metadata  Data about data.  Models are inherently metadata.  Parts catalogs, blue-prints, dictionaries etc.  Patterns and Metadata Amandeep S. Patti 39
  • 40. Constraints  Constraints are functional relationships between entities of an object model. The term entity includes objects, classes, attributes, links and associations.  A constraint restricts the values that entities can assume.  A good object model captures many constraints through its structure.  Object modeling notation for constraints is as follows: Constraints are delimited by braces and positioned near the constrained entity. A dotted line connects multiple constrained entities. Amandeep S. Patti 40
  • 41. Constraints Employe Window e Length Salary width {Salary <= boss.Salary} {length > width} Constraints on objects {ordered} Country Office Person Constraints on association links Amandeep S. Patti 41
  • 42. Derived Objects, Links and Attributes  A derived object is defined as a function of one or more objects, which in turn may be derived.  The notation for derived entity is a slash or diagonal line (on the corner of a class box, or an association line, or in front of an attribute). Machine Assembly Part offset offset Offset Amandeep S. Patti 42
  • 43. Homomorphism Maps Contains Contains CatalogItem Item Model number Serial number Describes {Item1 contains item2 => item1.model contains item2.model} Homomorphism for a parts catalog Amandeep S. Patti 43

Editor's Notes

  • #2: Object Oriented Analysis &amp; Design