MODULE -3
Chapter-1
Introduction
What Is Object-Orientation?
Superficially the term object-oriented (OO) means that we
organize software as a collection
of discrete objects that incorporate both data structure and
behavior.
There is some dispute about exactly what characteristics are
required by an OO approach, but they generally include four
aspects: identity, classification, inheritance, and polymorphism.
Identity means that data is quantized into discrete,
distinguishable entities called objects.
Classification means that objects with the same data structure
(attributes) and behavior (operations) are grouped into a class.
A class is an abstraction that describes properties important to
an application and ignores the rest. Any choice of classes is
arbitrary and depends on the application.
Each class describes a possibly infinite set of individual objects.
Each object is said to be an instance of its class. An object has its
own value for each attribute but shares the Attribute names and
operations with other instances of the class
Figure 1.2 shows two classes and some of their respective instances.
What Is OO Development?
In this context development refers to the software life cycle: analysis, design,
and implementation. The essence of OO development is the identification and
organization of application concepts, rather than their final representation in a
programming language.
Modeling Concepts, Not Implementation
OO development is a conceptual process independent of a programming
language until the final stages.
OO development is fundamentally a way of thinking and not a programming
technique. Its greatest benefits come from helping specifiers, developers, and
customers express abstract concepts clearly and communicate them to each other.
It can serve as a medium for specification, analysis, documentation, and
interfacing, as well as for programming
OO Methodology
The process consists of building a model of an application and then adding
details to it during design.
The same seamless notation is used from analysis to design to
implementation, so that information added in one stage of development need
not be lost or translated for the next stage. The methodology has the following
stages.
System conception. Software development begins with business analysts or
users conceiving an application and formulating tentative requirements.
Analysis:
The analyst scrutinizes and rigorously restates the requirements from system
conception by constructing models.
The analyst must work with the requestor to understand the problem, because
problem statements are rarely complete or correct.
The analysis model should not contain implementation decisions.
System design.
The development team devise a high-level strategy—the system architecture—
for solving the application problem.
The system designer must decide what performance characteristics to optimize,
choose a strategy of attacking the problem, and make tentative resource
allocations.
Class design.
The class designer adds details to the analysis model in accordance with the
system design strategy. The class designer elaborates both domain and
application objects using the same OO concepts and notation, although they exist
on different conceptual planes.
The focus of class design is the data structures and algorithms needed to
implement each class.
Implementation.
Implementers translate the classes and relationships developed during
class design into a particular programming language, database, or hardware.
Programming should be straightforward, because all of the hard decisions
should have Already been made.
During implementation, it is important to follow good software engineering
practice so that traceability to the design is apparent and so that the system
remains flexible and extensible.
OO concepts apply throughout the system development life cycle,
from analysis through design to implementation. You can carry the same
classes from stage to stage without a change of notation, although they
gain additional details in the later stages.
The analysis and implementation models of Window are both correct,
but they serve different purposes and represent a different level of
abstraction. The same OO concepts of identity, classification,
polymorphism, and inheritance apply throughout development.
Three Models
We use three kinds of models to describe a system from different viewpoints: the class
model for the objects in the system and their relationships; the state model for the life history
of objects; and the interaction model for the interactions among objects.
Each model applies during all stages of development and acquires detail as development
progresses. A complete description of a system requires models from all three viewpoints.
The class model describes the static structure of the objects in a system and their
relationships.
The class model defines the context for software development—the universe of
discourse. The class model contains class diagrams.
1. A class diagram is a graph whose nodes are classes and whose arcs are relationships
among classes.
2. The state model describes the aspects of an object that change over time. The state
model specifies and implements control with state diagrams.
A state diagram is a graph whose nodes are states and whose arcs are transitions between
states caused by events.
3. The interaction model describes how the objects in a system cooperate to achieve
broader results. The interaction model starts with use cases that are then elaborated with
Sequence and activity diagrams.
A use case focuses on the functionality of a system—that is,
what a system does for users.
A sequence diagram shows the objects that interact and the time
sequence of their interactions. An activity diagram elaborates
important processing steps.
The three models are separate parts of the description of a
complete system but are cross-linked. The class model is most
fundamental, because it is necessary to describe what is changing
or transforming before describing when or how it changes.
OO Themes
Abstraction
Abstraction lets you focus on essential aspects of an application while ignoring
details. This means focusing on what an object is and does, before deciding how to
implement it.
The ability to abstract is probably the most important skill required for OO
development.
Encapsulation
Encapsulation (also information hiding) separates the external aspects of an
object,
that are accessible to other objects, from the internal implementation details, that
are hidden from other objects.
You can change an object’s implementation without affecting the applications that
use it. You may want to change the implementation of an object to improve
performance, fix a bug, consolidate code, or support porting
Combining Data and Behavior
The caller of an operation need not consider how many
implementations exist.
Operator polymorphism shifts the burden of deciding what
implementation to use from the calling code to the class
hierarchy.
In an OO system, the data structure hierarchy matches the
operation inheritance hierarchy (Figure 1.3).
Sharing
OO techniques promote sharing at different levels. Inheritance of
both data structure and Behavior lets subclasses share common
code. This sharing via inheritance is one of the main advantages of
OO languages.
OO development not only lets you share information within an
application, but also offers the prospect of reusing designs and code
on future projects. OO development provides the tools, such as
abstraction, encapsulation, and inheritance, to build libraries of
reusable components.
Unfortunately, reuse has been overemphasized as a justification
for OO technology. Reuse does not just happen; developers must
plan by thinking beyond the immediate application and investing
extra effort in a more general design.
Emphasis on the Essence of an Object
OO technology stresses what an object is, rather than how it is
used. The uses of an object depend on the details of the application
and often change during development.
As requirements evolve, the features supplied by an object are
much more stable than the ways it is used, hence software systems
built on object structure are more stable in the long run.
OO development places a greater emphasis on data structure and a
lesser emphasis on procedure structure than functional-
decomposition methodologies. In this respect, OO development is
similar to information modeling techniques used in database design,
although OO development adds the concept of class-dependent
behavior.
Synergy
Identity, classification, polymorphism, and inheritance characterize
OO languages. Each of these concepts can be used in isolation, but
together they complement each other synergistically.
The benefits of an OO approach are greater than they might seem
at first. The emphasis on the essential properties of an object forces
the developer to think more carefully and deeply about what an
object is and does.
The resulting system tends to be cleaner, more general, and more
robust than it would be if the emphasis were only on the use of data
and operations.
Chapter -2
Modeling as a Design Technique
A model is an abstraction of something for the purpose of
understanding it before building it. Because a model omits
nonessential details, it is easier to manipulate than the original
entity.
Abstraction is a fundamental human capability that permits us to
deal with complexity.
To build complex systems, the developer must abstract different
views of the system, build models using precise notations, verify
that the models satisfy the requirements of the system, and
gradually add detail to transform the models into an
implementation.
Modeling
Designers build many kinds of models for various purposes before constructing
things. Examples include architectural models to show customers, airplane scale
models for wind-tunnel tests, pencil sketches for composition of oil paintings,
blueprints of machine parts, storyboards of advertisements, and outlines of books.
Models serve several purposes-
Testing a physical entity before building it.
Engineers test scale models of airplanes, cars, and boats in wind tunnels and water
tanks to improve their dynamics.
Recent advances in computation permit the simulation of many physical
structures without the need to build physical models.
Both physical models and computer models are usually cheaper than building a
complete system.
Communication with customers.
Architects and product designers build models to show their customers. Mock-ups
are demonstration products that imitate some or all of the external behavior of a
system.
Visualization.
Storyboards of movies, television shows, and advertisements let
writers see how their ideas flow. They can modify transitions, dangling
ends, and unnecessary segments before detailed writing begins.
Artists’ sketches let them block out their ideas and make changes
before committing them to oil or stone.
Reduction of complexity.
Perhaps the main reason for modeling, which incorporates all the
previous reasons, is to deal with systems that are too complex to
understand directly.
The human mind can cope with only a limited amount of information
at one time.
Models reduce complexity by separating out a small number of
important things to deal with at a time.
Abstraction
Abstraction is the selective examination of certain aspects of a problem. The goal
of abstraction is to isolate those aspects that are important for some purpose and
suppress those aspects that are unimportant.
The purpose of an abstraction is to limit the universe so we can understand. In
building models, therefore, you must not search for absolute truth but for adequacy
for some purpose.
A good model captures the crucial aspects of a problem and omits the others.
The Three Models
We find it useful to model a system from three related but different viewpoints,
each capturing important aspects of the system, but all required for a complete
description.
1. The class model represents the static, structural, “data” aspects of a system.
2. The state model represents the temporal, behavioral, “control” aspects of a
system.
3. The interaction model represents the collaboration of individual objects, the
“interaction” aspects of a system.
A typical software procedure incorporates all three aspects: It uses data
structures (class model), it sequences operations in time (state model), and it
passes data and control among objects (interaction model).
Each model contains references to entities in other models. For example, the
class model attaches operations to classes, while the state and interaction models
elaborate the operations.
Class Model
The class model describes the structure of objects in a system—their identity, their
relationships to other objects, their attributes, and their operations.
The class model provides context for the state and interaction models. Changes and
interactions are meaningless unless there is something to be changed or with which to
interact.
In modeling an engineering problem, the class model should contain terms familiar
to engineers; in modeling a business problem, terms from the business; in modeling a
user interface, terms from the application.
The design model describes how to solve a problem and may contain computer
constructs.
Class diagrams express the class model. Generalization lets classes share structure
and behavior, and associations relate the classes. Classes define the attribute values
carried by each object and the operations that each object performs or undergoes.
State Model
The state model describes those aspects of objects concerned with
time and the sequencing of operations—events that mark changes,
states that define the context for events, and the organization of
events and states.
The state model captures control, the aspect of a system that
describes the sequences of operations that occur, without regard for
what the operations do, what they operate on, or how they are
implemented.
State diagrams express the state model. Each state diagram shows
the state and event sequences permitted in a system for one class of
objects. State diagrams refer to the other models.
Actions and events in a state diagram become operations on objects
in the class model.
References between state diagrams become interactions in the
interaction model.
Interaction Model
The interaction model describes interactions between objects—how
individual objects collaborate to achieve the behavior of the system as
a whole.
The state and interaction models describe different aspects of
behavior, and you need both to describe behavior fully.
Use cases, sequence diagrams, and activity diagrams document the
interaction model.
Use cases document major themes for interaction between the
system and outside actors.
Sequence diagrams show the objects that interact and the time
sequence of their interactions.
Activity diagrams show the flow of control among the processing steps
of a computation.
Relationship Among the Models
Each model describes one aspect of the system but contains references to the other
models.
The class model describes data structure on which the state and interaction models
operate.
The operations in the class model correspond to events and actions. The state model
describes the control structure of objects.
The interaction model focuses on the exchanges between objects and provides a
holistic overview of the operation of a system.
Some properties of a system may be poorly represented by the models. This is also
normal, because no abstraction is perfect; the goal is to simplify the system
description without loading down the model with so many constructs that it becomes
a burden and not a help.
For those things that the model does not adequately capture, natural language or
application- specific notation is still perfectly acceptable.
Chapter 3
Class Modeling
A class model captures the static structure of a system by
characterizing the objects in the system, the relationships between
the objects, and the attributes and operations for each class of
objects.
The class model is the most important of the three models.
We emphasize building a system around objects rather than
around functionality, because an object-oriented system more
closely corresponds to the real world and is consequently more
resilient with respect to change.
Class models provide an intuitive graphic representation of a
system and are valuable for communicating with customers.
Object and Class Concepts
Objects
The purpose of class modeling is to describe objects. An object is a
concept, abstraction or thing with identity that has meaning for an
application.
Some objects have real world counter parts while others are
conceptual entities.
The choice of objects depends on judgment and the nature of a
problem; there can be many correct representations.
All objects have identity and are distinguishable. Two apples with
the same color, shape, and texture are still individual apples; a person
can eat one and then eat the other. Similarly, identical twins are two
distinct persons, even though they may look the same.
The term identity means that objects are distinguished by their
inherent existence and not by descriptive properties that they may
have.
Classes and Class Diagrams
An object is an instance or occurrence of a class. A class
describes a group of objects with the same properties (attributes),
behavior (operations), kinds of relationships and semantics.
Class diagrams provide a graphic notation for modeling
classes and their relationships, thereby describing possible
objects. Class diagrams are useful both for abstract modeling
and for designing actual programs.
An object diagram shows individual objects and their
relationships. A class diagram corresponds to an infinite set of
object diagrams.
Figure 3.1 shows a class (left) and instances (right) described by it.
Objects JoeSmith, Mary Sharp, and an anonymous person are
instances of class Person.
The UML symbol for an object is a box with an object name followed
by a colon and the class name. The object name and class name are
both underlined. Our convention is to list the object name and class
name in boldface.
The UML symbol for a class also is a box. Our convention is to list the
class name in boldface, center the name in the box, and capitalize the
first letter.
Relationship Among the Models
A value is a piece of data. You can find values by examining problem documentation
for examples.
An attribute is a named property of a class that describes a value held by each object
of the class. You can find attributes by looking for adjectives or by abstracting typical
values.
The following analogy holds: Object is to class as value is to attribute. Structural
constructs— that is, classes and relationships (to be explained)—dominate class
models. Attributes are of lesser importance and serve to elaborate classes and
relationships.
Operations and Methods
An operation is a function or procedure that may be applied to or by objects
in a class. Hire, fire, and pay Dividend are operations on class Company.
Open, close, hide, and redisplay are operations on class Window. All objects in
a class share the same operations.
All objects in a class share the same operations. Each operation has a target
object as an implicit argument. The same operation may apply to many different
classes. Such an operation is polymorphic.
A method is the implementation of an operation for a class.
In Figure 3.4, the class Person has attributes name and birthdate and
operations change- Job and changeAddress. Name, birthdate, changeJob,
and changeAddress are features of Person.
Link and Association Concepts
Links and Associations
A link is a physical or conceptual connection among objects.
Example: Joe Smith Works-For Simplex Company. Most links relate 2
objects, but some links relates 3 or more objects. A link is an instance
of an association.
An association is a description of a group of links with common
structure and common semantics.
Example: a Person WorksFor a company. The links of an association
connect objects from the same classes.
An association describes a set of potential links in the same way
that a class describes a set of potential objects.
Example: Model for a financial application
Figure 3.7 is an excerpt of a model for a financial application. Stock brokerage
firms need to perform tasks such as recording ownership of various stocks,
tracking dividends, alerting customers to changes in the market, and computing
margin requirements. The top portion of the figure shows a class diagram and the
bottom shows an object diagram.
In the class diagram, a person may own stock in zero or more companies; a company
may have multiple persons owning its stock.
The asterisk is a multiplicity symbol. Multiplicity specifies the number of instances
of one class that may relate to a single instance of another class.
The UML notation for a link is a line between objects; a line may consist of several
line segments. If the link has a name, it is underlined.
The association name is optional, if the model is unambiguous. Ambiguity arises
when a model has multiple associations among the same classes (person works for
company and person owns stock in company).
The object diagram shows some examples. John, Mary, and Sue own stock in the GE
company. Sue and Alice own stock in the IBM company. Jeff does not own stock in any
company and thus has no link.
When there are multiple associations names are necessary. Associations are
inherently bidirectional. The name of a binary association usually reads in a particular
direction but the binary association can be traversed in either direction.
A reference is an attribute in one object that refers to another object.
Developers often implement associations in programming languages as
references from one object to another. A reference is an attribute in one object
that refers to another object.
For example, a data structure for Person might contain an attribute employer
that refers to a Company object, and a Company object might contain an
attribute employees that refers to a set of Person objects.
Multiplicity:
specifies the number of instances of one class that may relate to a
single instance of an associated class. UML diagrams explicitly list
multiplicity at the ends of association lines.
The UML specifies multiplicity with an interval, such as “1”
(exactly one), “1..*” (one or more), or “3..5” (three to five, inclusive).
The special symbol “*” is a shorthand notation that denotes “many”
(zero or more).
One – to- one association and some corresponding links:
Each country has one capital city. A capital city administers one
country.
Zero – or- one multiplicity:
A workstation may have one of its windows designated as the
console to receive general error messages. It is possible however,
that no console window exists.
Do not confuse “multiplicity” with “cardinality.” Multiplicity is a constraint on
the size of a collection; cardinality is the count of elements that are actually in a
collection. Therefore, multiplicity is a constraint on the cardinality.
A multiplicity of “many” specifies that an object may be associated with
multiple objects. However, for each association there is at most one link between
a given pair of objects . As Figure 3.10 and Figure 3.11 show, if you want two links
between the same objects, you must have two associations.
Association End Names
Multiplicity implicitly referred to the ends of associations.
Example: one – to – many associations has 2 ends – an end with a multiplicity
“one” and an end with a multiplicity “many” .
• Association end names are necessary for associations between 2
objects of the same class.
Container and contents distinguish the 2 usages of Directory in the
self – association. A directory may contain many lesser directories and
may optionally be contained itself. Association end names can also
distinguish multiple associations between the same pair of classes.
When constructing class diagrams you should properly use
association end names and not introduce a separate class for each
reference. Two instances represent a person with a child one for child
and one for parent.
In the correct model, one person instance participates in2 or more
links, twice as a parent and zero or more times as a child.
Ordering:
the objects on a ”many” association end have no explicit order and can
regard them as a set. However, the objects have explicit order some times.
A workstation screen contains a number of overlapping windows. Each
window on a screen occurs at most once. The windows have an explicit
order so only the topmost window is visible. The ordering is an inherent
part of the association. If objects indicate ordered set objects by writing
“{ordered}” next to appropriate association end.
Bags and Sequences: A binary association has at most one link for a pair of
objects. We can permit multiple links for a pair of objects by annotating an
association end with {bag} or {sequence}. A bag is a collection of elements
with duplicates allowed. A sequence is a ordered collection of elements with
duplicates allowed.
A itinerary is a sequence of airports and the same airport can be visited more
than once.
Association classes: As you describe the objects of a class with the attributes,
we can describe the links of an association with attributes. The UML represents
such information with an association class.
An association class is a association that is also a class. Like a class an
association can have attributes and operations and participate in associations.
Many – to -many associations – attributes unmistakably belong to the link
and cannot be ascribed to either object.
It is possible to fold attributes for one – to – one and one – to – many
associations into the class opposite a ”one” end. This is not possible for many
– to – many associations.
Association classes are an important aspect of class modeling because they
let you specify identity and navigation paths.
The association class has only one occurrence for each pairing of person and
company. In contrast there can be any number of occurrences of purchase for
each person and company
Qualified Associations: is an association in which an attribute called the
qualifier disambiguates the objects for a “many” association end. It is
possible to define qualifiers for one – to – many and many –to – many
associations.
A qualifier selects among the target objects, reducing the effective
multiplicity from ”many” to “ one”.
Example: a bank services multiple accounts. An account belongs to a single
ban. Within the context of a bank, the account number specifies unique
account. Bank and Account are classes and account Number is the qualifier.
Qualification reduces the effective multiplicity from one to many to one to
one.
The qualified model adds multiplicity constraint, that the
combination of a bank and an account number yields at
most one account. The model conveys the significance of
account number in traversing the model, as methods will
reflect. You 1st specify the bank and then the account
number to find the account.
The notation for qualifier → small box on the end of the
association line near the source class. The box may grow
out of any side ( top, bottom, left, right).
The source class and qualifier yields target class.
Generalization and Inheritance:
Generalization is the relationship between a class (super class) and one or
more variations of the class (subclasses).
Generalization organizes classes by their similarities and different
structuring the description of objects.
The super class holds common attributes, operations and associations; the
sub classes add specific attributes, operations and associations. Each sub
class is said to inherits the features of its super class.
Generalization is sometimes called the “is – a” relationship, because each
instance of a sub class is a instance of the super class.
A large hollow arrowhead denotes
generalization. The arrowhead
points to the super class.
The terms ancestor and descendent refer to generalization of
classes across multiple levels. Use of Generalization: has 3
purposes,
one of which is support for polymorphism. Polymorphism
increases the flexibility of software you add a new sub class
and automatically inherit super class behavior.
The second purpose of generalization is to structure the
description of objects. When generalization is used, you are
making a conceptual statement you are forming a taxonomy
and organizing objects on the basis of their similarities and
differences.
The third purpose is to enable reuse of code inherit code
within the application as well as from part work (class
library). The terms generalization, specialization and
inheritance all refer to aspects of the same idea.
Overriding Features:
A sub class may override a super class feature by defining a feature
with the same name. There are several reasons to override a feature:
to specify behavior that depends on the sub class, to tighten the
specification of a feature or to improve performance.
Navigation of Class Models:
Navigation is important because it lets you exercise a model and
uncover hidden flaws and omissions so that you can repair them. You can
perform navigation manually or write navigation expressions.
Consider the simple model for credit card accounts:
An institution may issue many credit card accounts, each identified by an account
number. Each account has a maximum credit limit, a current balance and a mailing
address. The account server one or more customers who reside at the mailing address.
The institution periodically issues statement for each account. The statement lists a
payment DueDate, financeCharge and minimum Payment. The statement itemizes
various transactions that have occurred throughout the billing interval: cash advances,
interest charges, purchases, fees and adjustments to the account. The name of the
merchant is printed for each purchase.
We pose a variety of questions against the model.
*What transactions occurred for a credit card account within a time interval?
*What volume of transactions were handled by an institution in the last year?
*What customers patronized a merchant in the last year by any kind of credit
card?
*How many credit card accounts does a customer currently have?
*What is the total maximum credit for a customer, for all accounts?
The UML incorporates a language that can express these kinds of
questions –the object Constraint language (OCL).
OCL Constructs for traversing Class Models
Attributes: You can traverse from an object to an attribute value.
Syntax: source object, followed by a dot and then the attribute name.
Example: a Credit Card Account. Maximum Credit.
Operations: You can also invoke an operation for an object or a collection
of objects.
Syntax: source object or object collection, followed by a dot and then the
operation. The operation must be followed by parentheses.
The syntax for a collection operation is the source object collection
followed by” ―> “and then the operation.
Simple associations: A 3rd use of dot notation is to traverse an association
to a target end.
Example: a Customer. Mailing Address yields a set of addresses for a
customer.
Qualified associations: A qualifier lets you make a more precise traversal.
The expression a CreditCard Account.Statement[30 November 1999] finds the
statement for a credit card account with the statement date 30 November
1999.
Generalizations: Traversal is implicit for the OCL notation.
Filters: OCL has several kinds of filters, most common of which is the select
operation.
Example: aStatement.transaction select(amount>$100) finds the transactions
for a statement in excess of $100000
Chapter – 4
Advanced objects and class concepts
Enumerations
A data type is a description of values, includes numbers, strings,
enumerations .
Enumerations: A Data type that has a finite set of values.
When constructing a model, we should carefully note enumerations,
because they often occur and are important to users.
Enumerations are also significant for an implantation; we may display the
possible values with a pick list and you must restrict data to the legitimate
values.
Do not use a generalization to capture the values of an Enumerated
attribute.
An Enumeration is merely a list of values; generalization is a means for
structuring the description of objects.
We can declare an enumeration by listing the keyword enumeration in
guillemets (<< >>) above the enumeration name in the top section of a box. The
second section lists the enumeration values.
Eg: Boolean type= { TRUE, FALSE}
Eg: figure.pentype
Two diml.filltype
Multiplicity
Multiplicity is a collection on the cardinality of a set, also applied to
attributes (database application).
Multiplicity of an attribute specifies the number of possible values for each
instantiation of an attribute. i.e., whether an attribute is mandatory ( [1] ) or
an optional value ( [0..1] or * i.e., null value for database attributes ) .
Scope
Scope indicates if a feature applies to an object or a class.
An underline distinguishes feature with class scope (static) from those
with object scope.
Our convention is to list attributes and operations with class scope at the
top of the attribute and operation boxes, respectively.
It is acceptable to use an attribute with class scope to hole the extent of a
class (the set of objects for a class) - this is common with OO databases.
Visibility
Visibility refers to the ability of a method to reference a feature from another
class and has the possible values of public, protected, private, and package.
Any method can access public features.
Only methods of the containing class and its descendants via inheritance can
access protected features.
Only methods of the containing class can access private features.
The UML denotes visibility with a prefix. ”+” public, “-” private, “#”
protected, “~” package. Lack of a prefix reveals no information about visibility.
Several issues to consider when choosing visibility are
Comprehension: understand all public features to understand the capabilities of
a class. In contrast we can ignore private, protected, package features – they are
merely an implementation convince.
Extensibility: many classes can depend on public methods, so it can be highly
disruptive to change their signature. Since fewer classes depend on private,
protected, and package methods, there is more latitude to change them.
Context: private, protected, and package methods may rely on preconditions or
state information created by other methods in the class. Applied out of context, a
private method may calculate incorrect results or cause the object to fail.
Associations ends
Association End is an end of association.
A binary association has 2 ends; a ternary association has 3
ends.
N-ary Association
We may occasionally encounter n-ary associations (association among 3
or more classes). But we should try to avoid n-ary associations- most of
them can be decomposed into binary associations, with possible qualifiers
and attributes.
The UML symbol for n-ary associations is a diamond with lines connecting
to related classes. If the association has a name, it is written in italics next to
the diamond.
The OCL does not define notation for traversing n-ary associations.
A typical programming language cannot express n-ary associations. So,
promote nary associations to classes. Be aware that you change the meaning of
a model, when you promote n-ary associations to classes.
An n-ary association enforces that there is at most one link for each
combination.
Aggregation
Aggregation is a strong form of association in which an aggregate object is
made of constituent parts.
Constituents are the parts of aggregate.
The aggregate is semantically an extended object that is treated as a unit in
many operations, although physically it is made of several lesser objects. We
define an aggregation as relating an assembly class to one constituent part class.
An assembly with many kinds of constituent parts corresponds to many
aggregations.
The most significant property of aggregation is transitivity (if A is part of B and
B is part of C, then A is part of C) and antisymmetric (if A is part of B then B is not
part of A)
Aggregation versus Association
Aggregation is a special form of association, not an independent concept.
Aggregation adds semantic connotations.
If two objects are tightly bound by a part-whole relationship, it is an
aggregation. If the two objects are usually considered as independent, even
though they may often be linked, it is an association.
Aggregation is drawn like association, except a small (hollow) diamond
indicates the assembly end.
Aggregation versus Composition
The UML has 2 forms of part-whole relationships: a general form called
Aggregation and a more restrictive form called composition.
Composition is a form of aggregation with two additional constraints.
A constitute part can belong to at most one assembly.
Once a constitute part has been assigned an assembly, it has a coincident
lifetime with the assembly. Thus composition implies ownership of the parts by
the whole.
This can be convenient for programming: Deletion of an assembly object
triggers deletion of all constituent objects via composition.
Abstract Classes
Abstract class is a class that has no direct instances but whose descendant
classes have direct instances. A concert class is a class that is insatiable; that is,
it can have direct instances. A concrete class may have abstract class.
In UML notation an abstract class name is listed in an italic (or place the
keyword {abstract} below or after the name). We can use abstract classes to
define the methods that can be inherited by subclasses.
Multiple Inheritance
Multiple inheritance permits a class to have more than one superclass and to inherit
features from all parents. We can mix information from 2 or more sources. This is a more
complicated from of generalization than single inheritance, which restricts the class
hierarchy to a tree.
The advantage of multiple inheritance is greater power in specifying classes and an
increased opportunity for reuse. The disadvantage is a loss of conceptual and
implementation simplicity.
Kinds of Multiple Inheritance
•The most common form of multiple inheritance is from sets of disjoint classes.
Each subclass inherits from one class in each set.
•The appropriate combinations depend on the needs of an application.
•Each generalization should cover a single aspect.
•We should use multiple generalizations if a class can be refined on several
distinct and independent aspects.
Multiple Classification
An instance of a class is inherently an instance of all ancestors of the class. For
example, an instructor could be both faculty and student.
Metadata
Metadata is data that describes other data. For example, a class definition is a
metadata. Models are inherently metadata, since they describe the things being
modeled.
We can also consider classes as objects, but classes are meta-objects and not
realworld objects. Class descriptor object have features, and they in turn have their
own classes, which are called metaclasses.
Reification
•Reification is the promotion of something that is not an object into an object.
Reification is a helpful technique for Meta applications because it lets you shift
the level of abstraction.
•On occasion it is useful to promote attributes, methods, constraints, and control
information into objects so you can describe and manipulate them as data.
•As an example of reification, consider a database manager. A developer could
write code for each application so that it can read and write from files. Instead, for
many applications, it is better idea to reify the notion of data services and use a
database manager. A database manager has abstract functionality that provides a
generalpurpose solution to accessing data reliably and quickly for multiple users.
Constraints
Constraint is a condition involving model elements, such as objects, classes,
attributes, links, associations, and generalization sets. A Constraint restricts the
values that elements can assume by using OCL.
Derived Data
A derived element is a function of one or more elements, which in turn may be
derived. A derived element is redundant, because the other elements completely
determine it. the derivation tree terminates with base elements. Classes,
associations, and attributes may be derived. The notation for a derived element is
a slash in front of the element name along with constraint that determines the
derivation.
Packages
•A package is a group of elements (classes, association, generalization, and lesser
packages) with a common theme.
•A package partitions a model, making it easier to understand and manage.
•A package partitions a model making it easier to understand and manage. Large
applications my require several tiers of packages.
•Packages form a tree with increasing abstraction toward the root, which is the
application, the top-level package.
Notation for pakage is a box with a tab.