SlideShare ist ein Scribd-Unternehmen logo
1 von 43
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

Weitere ähnliche Inhalte

Was ist angesagt?

System Models in Software Engineering SE7
System Models in Software Engineering SE7System Models in Software Engineering SE7
System Models in Software Engineering SE7
koolkampus
 
Relational algebra in dbms
Relational algebra in dbmsRelational algebra in dbms
Relational algebra in dbms
shekhar1991
 
Software Quality Attributes
Software Quality AttributesSoftware Quality Attributes
Software Quality Attributes
Hayim Makabee
 

Was ist angesagt? (20)

Introduction to UML
Introduction to UMLIntroduction to UML
Introduction to UML
 
Coupling and cohesion
Coupling and cohesionCoupling and cohesion
Coupling and cohesion
 
11 deployment diagrams
11 deployment diagrams11 deployment diagrams
11 deployment diagrams
 
10 component diagram
10 component diagram10 component diagram
10 component diagram
 
Activity diagram
Activity diagramActivity diagram
Activity diagram
 
Cohesion and coupling
Cohesion and couplingCohesion and coupling
Cohesion and coupling
 
UML Diagrams
UML DiagramsUML Diagrams
UML Diagrams
 
OOAD UNIT I UML DIAGRAMS
OOAD UNIT I UML DIAGRAMSOOAD UNIT I UML DIAGRAMS
OOAD UNIT I UML DIAGRAMS
 
Overview of UML Diagrams
Overview of UML DiagramsOverview of UML Diagrams
Overview of UML Diagrams
 
System Models in Software Engineering SE7
System Models in Software Engineering SE7System Models in Software Engineering SE7
System Models in Software Engineering SE7
 
Advanced Structural Modeling
Advanced Structural ModelingAdvanced Structural Modeling
Advanced Structural Modeling
 
UML- Unified Modeling Language
UML- Unified Modeling LanguageUML- Unified Modeling Language
UML- Unified Modeling Language
 
OOAD - UML - Sequence and Communication Diagrams - Lab
OOAD - UML - Sequence and Communication Diagrams - LabOOAD - UML - Sequence and Communication Diagrams - Lab
OOAD - UML - Sequence and Communication Diagrams - Lab
 
object oriented methodologies
object oriented methodologiesobject oriented methodologies
object oriented methodologies
 
Importance & Principles of Modeling from UML Designing
Importance & Principles of Modeling from UML DesigningImportance & Principles of Modeling from UML Designing
Importance & Principles of Modeling from UML Designing
 
Design Concept software engineering
Design Concept software engineeringDesign Concept software engineering
Design Concept software engineering
 
Relational algebra in dbms
Relational algebra in dbmsRelational algebra in dbms
Relational algebra in dbms
 
Software Quality Attributes
Software Quality AttributesSoftware Quality Attributes
Software Quality Attributes
 
Class diagram
Class diagramClass diagram
Class diagram
 
Presentation on uml
Presentation on umlPresentation on uml
Presentation on uml
 

Ähnlich wie Object modeling

Ch.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptx
Ch.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptxCh.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptx
Ch.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptx
SohagSrz
 
08 class and sequence diagrams
08   class and sequence diagrams08   class and sequence diagrams
08 class and sequence diagrams
kebsterz
 

Ähnlich wie Object modeling (20)

Object modeling
Object modelingObject modeling
Object modeling
 
Ch.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptx
Ch.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptxCh.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptx
Ch.03 - Class Diagram_1 OBJECT ORIENTED ANALYSIS AND DESIGN [O] .pptx
 
Unit 2(advanced class modeling & state diagram)
Unit  2(advanced class modeling & state diagram)Unit  2(advanced class modeling & state diagram)
Unit 2(advanced class modeling & state diagram)
 
UML
UMLUML
UML
 
OMD chapter 2 Class modelling
 OMD  chapter 2 Class modelling OMD  chapter 2 Class modelling
OMD chapter 2 Class modelling
 
Uml - An Overview
Uml - An OverviewUml - An Overview
Uml - An Overview
 
Interfaces & Packages V2
Interfaces & Packages V2Interfaces & Packages V2
Interfaces & Packages V2
 
Css uml
Css umlCss uml
Css uml
 
Chapter3
Chapter3Chapter3
Chapter3
 
OO Development 4 - Object Concepts
OO Development 4 - Object ConceptsOO Development 4 - Object Concepts
OO Development 4 - Object Concepts
 
Introduction to UML
Introduction to UMLIntroduction to UML
Introduction to UML
 
Jar chapter 2
Jar chapter 2Jar chapter 2
Jar chapter 2
 
SE18_Lec 06_Object Oriented Analysis and Design
SE18_Lec 06_Object Oriented Analysis and DesignSE18_Lec 06_Object Oriented Analysis and Design
SE18_Lec 06_Object Oriented Analysis and Design
 
Erm
ErmErm
Erm
 
Erm
ErmErm
Erm
 
2 class use case
2 class use case2 class use case
2 class use case
 
SE_Lec 06_Object Oriented Analysis and Design
SE_Lec 06_Object Oriented Analysis and DesignSE_Lec 06_Object Oriented Analysis and Design
SE_Lec 06_Object Oriented Analysis and Design
 
Object Oriented Principles
Object Oriented PrinciplesObject Oriented Principles
Object Oriented Principles
 
Object diagram
Object diagramObject diagram
Object diagram
 
08 class and sequence diagrams
08   class and sequence diagrams08   class and sequence diagrams
08 class and sequence diagrams
 

Mehr von Anand Grewal

Mehr von Anand Grewal (12)

distributed dbms
distributed dbmsdistributed dbms
distributed dbms
 
Transaction concurrency control
Transaction concurrency controlTransaction concurrency control
Transaction concurrency control
 
Object analysis and design
Object analysis and designObject analysis and design
Object analysis and design
 
O ops concepts
O ops conceptsO ops concepts
O ops concepts
 
System design
System designSystem design
System design
 
Presentation12
Presentation12Presentation12
Presentation12
 
Presentation1
Presentation1Presentation1
Presentation1
 
Event handling
Event handlingEvent handling
Event handling
 
Isp
IspIsp
Isp
 
Java
JavaJava
Java
 
Pptemail
PptemailPptemail
Pptemail
 
Presentation on dns
Presentation on dnsPresentation on dns
Presentation on dns
 

Kürzlich hochgeladen

Russian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in Delhi
Russian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in DelhiRussian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in Delhi
Russian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in Delhi
kauryashika82
 
Seal of Good Local Governance (SGLG) 2024Final.pptx
Seal of Good Local Governance (SGLG) 2024Final.pptxSeal of Good Local Governance (SGLG) 2024Final.pptx
Seal of Good Local Governance (SGLG) 2024Final.pptx
negromaestrong
 

Kürzlich hochgeladen (20)

Class 11th Physics NEET formula sheet pdf
Class 11th Physics NEET formula sheet pdfClass 11th Physics NEET formula sheet pdf
Class 11th Physics NEET formula sheet pdf
 
Advanced Views - Calendar View in Odoo 17
Advanced Views - Calendar View in Odoo 17Advanced Views - Calendar View in Odoo 17
Advanced Views - Calendar View in Odoo 17
 
On National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan FellowsOn National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan Fellows
 
PROCESS RECORDING FORMAT.docx
PROCESS      RECORDING        FORMAT.docxPROCESS      RECORDING        FORMAT.docx
PROCESS RECORDING FORMAT.docx
 
General Principles of Intellectual Property: Concepts of Intellectual Proper...
General Principles of Intellectual Property: Concepts of Intellectual  Proper...General Principles of Intellectual Property: Concepts of Intellectual  Proper...
General Principles of Intellectual Property: Concepts of Intellectual Proper...
 
Holdier Curriculum Vitae (April 2024).pdf
Holdier Curriculum Vitae (April 2024).pdfHoldier Curriculum Vitae (April 2024).pdf
Holdier Curriculum Vitae (April 2024).pdf
 
Role Of Transgenic Animal In Target Validation-1.pptx
Role Of Transgenic Animal In Target Validation-1.pptxRole Of Transgenic Animal In Target Validation-1.pptx
Role Of Transgenic Animal In Target Validation-1.pptx
 
How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17
 
Micro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfMicro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdf
 
Unit-V; Pricing (Pharma Marketing Management).pptx
Unit-V; Pricing (Pharma Marketing Management).pptxUnit-V; Pricing (Pharma Marketing Management).pptx
Unit-V; Pricing (Pharma Marketing Management).pptx
 
Introduction to Nonprofit Accounting: The Basics
Introduction to Nonprofit Accounting: The BasicsIntroduction to Nonprofit Accounting: The Basics
Introduction to Nonprofit Accounting: The Basics
 
Presentation by Andreas Schleicher Tackling the School Absenteeism Crisis 30 ...
Presentation by Andreas Schleicher Tackling the School Absenteeism Crisis 30 ...Presentation by Andreas Schleicher Tackling the School Absenteeism Crisis 30 ...
Presentation by Andreas Schleicher Tackling the School Absenteeism Crisis 30 ...
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibit
 
Russian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in Delhi
Russian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in DelhiRussian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in Delhi
Russian Escort Service in Delhi 11k Hotel Foreigner Russian Call Girls in Delhi
 
ICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptx
 
Seal of Good Local Governance (SGLG) 2024Final.pptx
Seal of Good Local Governance (SGLG) 2024Final.pptxSeal of Good Local Governance (SGLG) 2024Final.pptx
Seal of Good Local Governance (SGLG) 2024Final.pptx
 
microwave assisted reaction. General introduction
microwave assisted reaction. General introductionmicrowave assisted reaction. General introduction
microwave assisted reaction. General introduction
 
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
 
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Ữ Â...
 
Application orientated numerical on hev.ppt
Application orientated numerical on hev.pptApplication orientated numerical on hev.ppt
Application orientated numerical on hev.ppt
 

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

Hinweis der Redaktion

  1. Object Oriented Analysis &amp; Design