3 Object Modeling
3 Object Modeling
at hand. Object serve two purpose: They promote understanding of the real world and provide a practical basis for computer implementation. Decomposition of a problem into objects depend on judgment and the nature of the problem. All objects have identity and are distinguishable. Twins are two identical persons, even though they may look the same. The term identity means that objects are distinguished by their inherent existent and not by descriptive properties that they may have. The word object is often vaguely used in the literature. Sometime object means a single times it refers to a group of Similar things. Usually the context resolves any ambiguity.
CLASSES An objects class describes a group of objects with similar properties , common behavior, common relationship to other objects and common semantics. The abbrevation class is often used instead of objects classes. Objects in a class have the Same attributes and behavior patterns. Most objects derive their individuality from difference in there attribute values and relationship to another. The objects in a class shares a common semantic purpose, above and beyond there equipment of common attributes and behavior. Each object "knows" its class. Most object oriented programming languages can determine an objects class at run time. If objects are the focus of object modeling why both wit h classes? The notation of abstraction at the heart of t e matter. By grouping into objects into classes, we abstract a problem . Abstraction gives modeling its power and ability to generalize from a few specific case to a host of similar cases. Operations can be written once per instances. Operation s can be written on e for each class, so that all the objects in the class benefits from code reuse. Even special cases, such as circles and squares, can use the general procedure, though more efficient procedures are possible.
attribute has a value for each , as illustrated by the sample data at the bottom of the figure The OMT notation for a link attribute is a box attached to the association by a loop one or more link attributes may appear In the Second region of the box. This notation emphasizes the similarity between attributes for links.
Many -to -many associations pro vi de the most compelling rati Dante for link attributes. Such an attribute is a property of the link and cannot be attached to either object. Access permission is a property of Yd e and User, and cannot b e attached to either File or User alone without I o sing Information
situations. After modeling a system the developed at the resulting classes and these to group simliar classes and reuse common code.
Aggregation
Aggregation is a strong form of association. An aggregaton is a complex object, which is made up of component objects. The individual parts may or may not exist independently. Semantically it is an extended object that is treated as a unit. It adds semantic connotation in some cases. If objects are tightly bound in a part hole relationship it might be usefuI to model the relationships as an aggregation. If not they shod be mode/led as normal relationships. The choice between using aggregation or not is one of judgement more then one of rules. Aggregation is not the same thing as generalization. In aggrega6on individual distinct objects is combined, one is part of the other. Generalization models the relationship subclass super-class. An object is simultaneously part of the both the subclass and the super-class. Both sub-class and superclass refer to the same object. Aggregation is seen as an part hole relationship and generalization is called "a kind of" or "is a". An aggregate can be fixed, variable or recursive. A fixed aggregate means that the number of subparts is predefined. In a variable aggregate the number of parts may vary. A recursive aggregate has directly or indirectly an instance of the same kind of aggregate. Propagation or triggering is a good indicator of aggregation. The trigger leads to the application of a network of operations. When moving an aggregate of its parts moves.
Abstract classes
An abstract class is a class that has no Instances but whose descendent classes have direct instances. A concrete class is a class that Is instantiable that is can Ieave direct instances. A concrete class may have abstrct classes. A concrete class may be a Ieaf class in the Inheritance tree only concrete classes may be the Ieaf class In the inheritance tree. The figure shows the definition o f abstract class an d concrete class . the dotted line IS the objct modeling notation for Instantiation. Abstract classes organize features to several classes. It is open useful to create an abstract Super class to encapsulate classes that participate In the association or aggregation . Zorne abstract classes appear naturally In the application domain . Other abstract classes are artificially introduced as a mechanism for promoting code rense.
Overriding for restriction: The new operation restricts the protocol such astightening the type of arguments. This may necessary to keep the inherited operation closed with in the subclass.
METADATA
Meta data is data that describes other data. Models are inherently metadata, since they describe the things being modelled. Patterns and Metadata Real world things may be metadata. There are real world things that describe other realworld things, Iike a blueprint describes a house.
Object Design During object design, developers define solution domain objects to bridge the gap between the analysis model and the hardware/software platform defined during system design. This includes precisely describing object and subsystem interfaces, selecting off-the-shelf components, restructuring the object model to attain design goals such' as extensibility or understandability, and optimizing the object model for performance. The result of the object design activity is a detailed object model annotated with constraints and precise descriptions for each clement. Object design includes reuse, during which we identify off-the-shelf components and design patterns to make use of existing solutions service specification, during which we precisely describe each class interface object model restructuring, during which we transform the object design model to improve its understandability and extensibility object model optimization, during which we transform the object design model to address performance criteria such as response time or memory utilization. Object design like system design is not algorithmic. Object design is not sequential. The interface specification activities of object design include
identifying missing attributes and operations specifying type signatures and visibility specifying invariants specifying preconditions and postconditions.
Dynamic modeling
Events and states An object model describes the possible patterns of objects, attributes and links that can exist in a system. The attribute values and links held by an object are called its state. Over time, the objects stimulate each other, resulting in a series of changes to their states. An individual stimulus from one objet to another is called an event. The pattern of events, states and state transitions for a given class can be abstracted and represented as a state diagram. The dynamic model consists of multiple state diagrams, one state diagram for each class with important dynamic behavior. Events An event is a something that happens at a point of time. An event has no duration. One event may logically precede or follow another, or the two events may be unrelated. Two events that are causally unrelated are said to be concurrent, they have no effect on each other. An event is one way transmission of information from one object to another. An object sending an event to another object may expect a reply, but the reply is a separate event under control of the second object, which may or may not choose to send it. An event conveys information from one object to another. Some classes of events may be simply signals that something has occurred, while other classes of events convey data values. The data values of an event are its attributes. Example of event classes and attributes
airplane flight departs (airline, flight num, city) mouse button pushed (button, location) input string entered(text) phone receiver lifted dialed(digit) speed enters danger zone
digit engine
Scenarios and event traces A scenario is a sequence of events that occurs during one particular execution of a system. The scope of scenario can vary; it may include all events in a system, or it may include only those events impinging on or generated by certain objects in a system. A scenario for a phone call Caller lifts receiver tone begins dials digit (5) tone ends Caller dials digit (5) Caller dials digit (5) Caller dials digit (1) Caller dials digit (2) Caller dials digit (3) Caller dials digit (4) Called phone begins ringing Ringing tone appears in calling phone Called party answers Called phone stops ringing Ringing tone disappears in calling phone Phones are connected Called party hangs up Dial Caller Dial
Phones are disconnected Caller hangs up Each event transmits information from one object to another. The next after writing a scenario is to identify the sender and receiver objects of each event. The sequence of events and the objects exchanging events can both be in an augmented scenario called an event trace diagram
Caller lifts receiver Dial tone begins Caller dials digit (5) Dial tone ends Caller dials digit (5) Caller dials digit (5) Caller dials digit (1) Caller dials digit (2) Caller dials digit (3) Caller dials digit (4) Ringing tone phone rings Answers phone Tone stops Phones connected ringing stops Phones connected
Caller
phone line
callee
States A state is an abstraction of the attributes values and links of an object. Sets of values are grouped together into a state according to properties that affect the gross behavior of the object. A state specifies the response of the object to input events. The response to an event received by an object may vary quantitatively depending on the exact values of its attributes, but the responses are quantitatively the same for all values within the same state, and may be quantitatively different for values in different states. A state has duration it occupies an interval of time. A state is associated with a continuous activity. In defining state we ignore those attributes that do not affect the behavior of the object, and we lump together in a single state all combinations of attribute values and links that have the same responses to events. State diagrams A state diagram relates events and states. When an event is received the next state depends on the current state as well as event, a change of state caused by an event is called a transition. A state diagram is a graph whose nodes are states and whose directed arcs are transitions labeled by an event names. A state is drawn in rounded box containing an optional name. a transition is drawn as an arrow from the receiving state to the target state; the label on the arrow is the name of the events causing the transition. All the transitions leaving a state must correspond to different events. The state diagram specifies the state sequence
caused by an event sequence. It also represent one shot life cycles or continuous loops.
OPERATIONS
Controlling Operations An activity is a operation that take time to complete. An activity is associated with a state. Activities include continuous operations as sequential operations that terminate by themselves after an interval of time. The notation "do: A" within a state box indicates that activity A starts on entry to the state and stop on exit. The same notation "do: A" indicates that sequential activity A begins on entry to the state and stop when complete. An action is an instantaneous operation. An action is associated with an event. An action represent an operation whose duration is insignificant compared to the resolution of the state diagram. A real-world operation is not really instantaneous. Actions can also represent internal control operations, such as getting attributes or generating other events.The notations for an action on a transition is a slash ('/') and the name of the action , following the name of the event causes it. Fig. Action for pop-up menu