1. Why is object oriented system important? State 2 orthogonal views of the software ?
Ans: In an object-oriented environment, software is a collection of discrete objects that encapsulate their data as
well as the functionality to model real world objects. In an object oriented system, everything is an object and
each object is responsible for itself. In a payroll application, instead of saying, System, compute the payroll of this
employee, you tell the employee object, Compute your payroll. Object oriented systems are easier to adapt to
changing requirements, easier to maintain, more robust, and promote greater design and code reuse.
Higher level of abstraction. Top-down approach supports abstraction at the function level. The object-oriented
approach supports abstraction at the object level. Since objects encapsulate both data (attributes) and functions
(methods), they work at a higher level of abstraction.
Seamless transition among different phases of software development. The object-oriented approach essentially
uses the same language to talk about analysis, design, programming and database design. This seamless approach
reduces the level of complexity and redundancy and makes for clearer, more robust system development.
Encouragement of good programming techniques. In a properly designed system, the classes will be grouped into
subsystems but remain independent. Therefore, changing one class has no impact on other classes, and so, the
impact is minimized which encourages good programming.
Promotion of reusability. Objects are reusable because they are modeled directly out of real-world problem
domain. The object orientation adds inheritance, which is a powerful technique that allows classes to be built from
each other and therefore, only d
differences and enhancements between the classes need to be designed and coded
Two orthogonal views of the software
Niklaus Wirth, the inventor of Pascal says:
Algorithms + Data structures = Programs
A software system is a set of mechanisms for performing certain action on certain data. Traditional development
techniques focus on the functions of the system. Object oriented systems development centers on object, which
combines data and functionality.
2. Explain about Encapsulation & information hiding and Class hierarchy
Ans: Information hiding is the principle of concealing the internal data and procedures of an object and providing an
interface to each object in such a way as to reveal as little as possible about its inner workings. C++ has a very
general encapsulation protection mechanism with public, private, and protected members. Public members
(member data and member functions) may be accessed from anywhere. Private members are accessible one from
within a class. An object data representation, such as a list or an array, usually will be private. Protected members
can be accessed only from subclasses.
In per-class protection, the most common form (e.g. Ada, C++, Eiffel), class methods can access any object of that
class and not just the receiver. In per-object protection, methods can access only the receiver.
An important factor in achieving encapsulation is the design of different classes of objects that operate using
common protocol, or objects user interface. This means that many objects will respond to the same message but
each will perform the message using operations tailored to its class.
Data abstraction is the benefit of the object-oriented concept that incorporates encapsulation and polymorphism.
Class hierarchy
An object-oriented system organizes classes into a subclass-superclass hierarchy. Different properties and behaviors
are used as the basis for making distinctions between classes and subclasses. At the top of the class hierarchy are the
most general classes and at the bottom are the most specific. A subclass inherits all of the properties and methods
(procedures) defined in its superclass. Subclasses generally add new methods and properties specific to that class.
Subclasses may refine or constrain the state and behavior inherited from its superclass.
An object-oriented system eliminates duplicated effort by allowing classes to share and reuse behaviors.
Formal or abstract classes have no instances but define the common behaviors that can be inherited by more
specific classes.
3. Describe Rumbaugh et al.s Object Modeling Technique
Ans: The Object Modeling Technique (OMT) presented by Jim Rumbaugh and his co-workers describes a method for
the analysis, design, and implementation of a system using an object-oriented technique. OMT is a fast, intuitive
approach for identifying and modeling all the objects making up a system. Details such as class attributes, method,
inheritance, and association also can be expressed easily. The dynamic behavior of objects within a system can be
described using the OMT dynamic model. This model lets you specify detailed state transitions and their descriptions
within a system. Finally, a process description and consumer-producer relationships can be expressed using OMTs
functional model. OMT consists of four phases, which can be performed iteratively:
1. Analysis. The results are objects and dynamic and functional models.
2. System design. The results are a structure of the basic architecture of the system along with high-level strategy
decisions.
3. Object design. This phase produces a design document, consisting of detailed objects static, dynamic, and
functional models.
4. Implementation. This activity produces reusable, extendable, and robust code.
OMT separates modeling into three different parts:
1. An object model, presented by the object model and the data dictionary.
2. A dynamic model, presented by the state diagrams and event flow diagrams.
3. A functional model, presented by data flow and constraints.
The object model
The object model describes the structure of objects in a system: their identity, relationships to other object
attributes, and operations. The object diagram contains classes interconnected by association lines. Each class
represents a set of individual objects. The association lines establish relationships among the classes. Each
association line represents a set of links from the objects of one class to the objects of another class.
1: The OMT object model of a bank system. The boxes represent classes and the filled triangle represents
specialization. Association between Account and Transaction is one to many; since one account can have many
transactions, the filled circle represents many (zero or more). The relationship between Client and Account classes is
one to one: A client can have only one account and account can belong to only one person (in this model joint
accounts are not allowed).
The OMT dynamic model
OMT provides a detailed and comprehensive dynamic model, in addition to letting you depict states, transitions,
events, and actions. The OMT state transition diagram is a network of states and events. Each state receives one or
more events, at which time it makes the transition to the next state. The next state depends on the current state as
well as the events.
2: State transition diagram for the bank application user interface. The round boxes represent states and the arrows
represent transitions.
The OMT functional model
The OMT data flow diagram (DFD) shows the flow of data between different processes in a business. An OMT DFD
provides a simple and intuitive method for describing business processes without focusing on the details of
computer systems.
Data flow diagrams use four primary symbols:
1.The process is any function being performed; for example, verify Password or PIN in the ATM system.
2.The data flow shows the direction of data element movement; for example, PIN code.
3. The data store is a location where data are stored; for example, account is a data store in the ATM example.
4. An external entity is a source or destination of a data element; for example, the ATM card reader.
Overall, the Rumbaugh et al. OMT methodology provides one of the strongest tool sets for the analysis and design of
object-oriented systems.
3: OMT DFD of the ATM system. The data flow lines include arrows to show the direction of data element
movement. The circles represent processes. The boxes represent external entities. A data store reveals the storage
of data.
4. Write short notes on : (i) Sequence Diagram (ii) Collaboration Diagram
Ans. Sequence Diagram
A sequence diagram is an interaction diagram that emphasizes the time ordering of messages. A
sequence diagram shows a set of objects and the messages sent and received by those objects. The
objects are typically named or anonymous instances of classes, but may also represent instances of other
things, such as collaborations, components, and nodes.
Collaboration Diagram
A collaboration diagram is an interaction diagram that emphasizes the structural organization of the
objects that send and receive messages. A collaboration diagram shows a set of objects, links among
those objects, and messages sent and received by those objects. The objects are typically named or
anonymous instances of classes, but may also represent instances of other things, such as collaborations,
components, and nodes.
5. Explain the 3 steps in extracting Entity Classes with a flowchart.
Ans: Entity class extraction consists of three steps that are carried out iteratively and incrementally:
Functional Modeling. Present scenarios of all the use cases (a scenario is an instance of a use case).
Class Modeling. Determine the entity classes and their attributes. Then, determine the interrelationships and
interactions between the entity classes. Present this information in the form of a Class Diagram.
Dynamic Modeling. Determine the operations performed by or to each entity class or subclass. Present this
information in the form of a Statechart.
6. What are the reasons that the operations not added during the analysis workflow, but rather during the
design workflow? Explain.
Ans. As a consequence of the iterative nature of the Unified Process, it is unwise to add an item to a UML
diagram before it is strictly necessary to do so.
Second, the operations to be allocated to the classes are deduced from the interaction diagrams of
the realizations of the use cases. In more detail, the messages in interaction diagrams are used to deduce
the operations of the information system. However, these interaction diagrams of realizations of use cases
are produced after the class diagram. In other words, first we determine the initial class diagram, and later
the interaction diagrams of the realizations of the use cases. We then use these interaction diagrams to
deduce the operations; only then can we allocate the operations to the classes.