Object Oriented Technic Notes (Unit3)
Object Oriented Technic Notes (Unit3)
Object Oriented Technic Notes (Unit3)
Object oriented analysis and design is the software engineering approach that models a system as group of interacting objects. Each object represents some entity that has properties and behaviors. Object Oriented Analysis (OOA) applies to analysis the functional requirement for a system. Object design the analysis model to produce implementation specification. In analysis phase we focus on what the system does and in design phase we focus on how the system does it. Object Oriented Analysis (OOA) is concerned with developing an object oriented model of an application. The identified objects reflect entities and operations that are associated with the problem to be solved. Object Oriented Design (OOD) process involves designing the object-classes and the relationship between these classes. When the design is released as an executing program, the required objects are created dynamically using class definition. Analysis The purpose of Analysis and Design are to: o Transform the requirements into system design. o Represent a robust architecture for the system. o The result of Analysis and Design is a Design Model that serve as an abstraction of the source code, i.e. the Design Model acts as a blueprint of how the source code is structured and written. o The Design Model consists of design classes structured into design package, it also contains description of how objects of these classes collaborate to perform use cases. o The design activities are centered around the notion of architecture. o Architecture is represented by a number of architectural views that capture the major structural design decisions.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 1
o The architecture is an important vehicle not only for developing good Design Model but also for increasing the quality of any model built during system development. Difference between Analysis & Design :
Easy mapping to the real world and easily verified by the customer. Easy to understand the analysis model. The analysis phase is independent of any programming language.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 2
Object Design:
Object Oriented Design (OOD) is a process that focuses on physical implementation of the system. Object Oriented Design (OOD) is concerned with developing Object Oriented Model (OOM) of a software system to implement the requirement which is identified during Object Oriented Analysis (OOA). Designs can be developed using objects that have been created in previous design. This reduces design, programming and validation costs. It may also lead to the use of standard objects and reduces the risks involved in software development. The term object and object-oriented are now widely used. They are applied to different type of entity, design methods, systems and programming language. An object is an entity that has a state and a defined set of operations which operate on that state. The state is represented as a set of object attributes. The operations associated with the object provide services to other objects which request these services when some computation is required. Objects are created according to an object class definition. An object class definition serves as a template for creating objects. It includes declarations of all the attributes and operations which should be associated with an object if that class. The six basic concepts of Object Oriented Design (OOD) are: o Objects. o Classes. o Encapsulation / Information Hiding. o Abstraction and Interface. o Inheritance. o Polymorphism.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 3
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 5
Designing Algorithm:
Each operation specified in the functional model must be formulated as an algorithm. The steps involve in designing algorithm, designer must: 1) Choosing Algorithm: It is very important to select the right algorithm. While choosing an algorithm following point should be considered: a) Computational Complexity:- For analyzing an algorithm, we determine the amount of resources (time and space) necessary to execute it efficiently. b) Ease Of Implementation & Understandability:- The algorithm should be easily understandable and can be easily implemented because to implement difficult algorithm need more man power and resources which increase the overall cost of project. c) Flexibility:- The client requests keeps on changing, it is very important that the algorithm should be adaptable to those changes. 2) Choosing Data Structure: Choosing algorithm involves choosing the data structure they work on. During object design we must choose the form of the data structure that will permit efficient algorithms. Data structure play very important role in the success and failure of an algorithm. 3) Defining Internal Classes & Operation: During the expansion of algorithms, new classes of objects may be needed to hold intermediate results. New, low-level operations may be invented during the decomposition of high-level operation. 4) Assigning Responsibility To Classes: Many operations have obvious target objects, but some operations can be performed at several places in an algorithm by several objects. Assigning responsibility for such operations can be frustrating. When a class is meaningful in the real world, then the operations on it are usually clear. When we have more than one objects in a system, we must decide which object plays the lead role in the system.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 6
Design Optimization:
The basic design model uses the analysis model as the framework for implementation. During design optimization, the designer must: 1) Adding Redundant Associations For Efficient Access: During analysis, it is undesirable to have redundancy in the association network because redundant association does not add any information. During design, however, we evaluate the structure of the object model for an implementation. The association that was useful during analysis may not form the most efficient network then network should be restructured by adding new associations. 2) Rearranging Execution Order For Efficiency: Efficiency: After adjusting the structure of the object model to optimize frequent traversals, the next thing to optimize is the algorithm itself. Actually, data structure and algorithm are directly related to each other, but we find that usually the data structure should be considered first. Re-computation: 3) Saving Derived Attributes To Avoid Re-computation: Data that is redundant because it can be derived from other data can be cached or stored in its computed from to avoid the overhead of recomputing it. New objects or classes may be defined to retain this information. The class that contains the cached data must be updated if any of the objects that it depends on are changed.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 7
Implementation Of Control:
The designer must refine the strategy for implementing the state-event models present in the dynamic model. There are three basic approaches to implementing the dynamic model: 1) State As Location Within A Program: The location of a control within a program implicitly defines the program state. One technique of converting a state diagram to code is as follows: a) Identify the main control path. Identify a path through the diagram that corresponds to the normally expected sequence of events. Write the names of states along this path as a linear sequence. This becomes a sequence of statements in the program. b) Identify alternate paths that branch off the main path and rejoin it later. These become conditional statement in the program. c) Identify backward path that branch off the main loop and rejoin it earlier. These become loops in the program. d) The states and transitions that remain correspond to execution condition. They can be handled by exception handling supported by the language. 2) State Machine Engine: This approach allows you to quickly progress from the analysis model to a skeleton prototype of the system by defining classes from the object model, state machine from the dynamic model, and creating stub of the action routines. A stub is the minimal definition of a function or subroutine without any internal code ( Code to return a pre-calculated or contrived values may be included). 3) Control As Concurrent Tasks: An object can be implemented as a task in the programming language. This is the most general approach, as it preserves the inherent concurrency of real objects. Events are implemented as inter-task calls using the facilities of the language. The task uses its location within the program to keep track of its state.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 8
Adjustment Of Inheritance:
As object design progresses, the definition of classes and operations can often be adjusted to increase the amount of inheritance. The designer should: Re1) Re-arranging Classes & Operations: Sometimes the same operation is defined across several classes and can easily be inherited from a common ancestor, more often operation in different classes are similar but not identical. The following kind of adjustment can be used to increase the chance of inheritance: a) Some operations may have fewer arguments than other. The missing argument can be added but ignored. b) Similar attributes in different classes may have different names. Give the attributes the same name and move them to a common ancestor class. c) An operation may be defined on several different classes in a group but be undefined on the other classes. Define it on the common ancestor class and declare it as a no-op on the classes that do not care about it. 2) Abstracting Out Common Behaviour: If a set of operations and attributes are common to two or more classes then a common super class can be created that implements the shared features, leaving only the specialized features in the sub classes. This transformation of object model is called abstracting out a common superclass or common behavior. 3) Use Delegation To Share Implementation: Inheritance is mechanism for implementing generalization, in which the behavior of a superclass is shared by all its subclasses. Sometimes programmer use inheritance as an implementation technique with no intention of guaranteeing the same behavior. It often happens that an existing class already implements some of the behavior that we want to provide in a newly defined class, although in other respect the two classes are different. The designer is then tempted to inherited from the existing class to achieve part of implementation of the new class. It is discouraged because; this can lead a problem if other operations that are inherited provide unwanted behavior.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 9
Object Representation:
Implementing objects is mostly straightforward, but the designer must choose when to use primitive types in representing objects and when to combine groups of related objects. Classes can be defined in terms of other classes, but eventually everything must be implemented in terms of built-in primitive data-types, like integer, float, string type. For Example : The designer must often choose whether to combine group of related objects. The given diagram shows two common implementation of 2-dimensional lines, one as a separate class and one embedded as attributes within the Point class.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 10
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 11
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 12
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 13
then-else and switch-case statement that associate condition with actions to perform. It has four quadrants: Condition Action Condition Alternative Action Entries
Process specification may also be expressed as Pseudo code. 3) Data Dictionary: Data Dictionary contains details which are missing from DFD. It is telling the database how to handle each column. The data dictionary defines data flows and data stores and the meaning of various attributes. 4) E-R Diagram: E-R Diagram highlights the relationships between data stores that otherwise would be only be seen in the process specifications. There are three basic notation in ER model: i) ii) iii) Entities : are the things. Attributes : are the data about entities. Relationship : provide the structure between entities.
ER diagrams are readily translated into a database implementation The above tools are used during the process of structured analysis; Structured Design follows structured analysis and addresses low-level details. Data flow diagram processes are converted into programming language functions, and a structure chart is created showing the procedure call tree.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 14
5) System Timing: In system timing step we consider, how much the model is permitted to log the real world. 6) Implementation: Implementation: In implementation step we focus on the problem of process scheduling and allocate processors to process.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 16
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 17
public void show(String a){} public void show(Runnable a){} public void show(int [] a){} public void show(String [] a){}
Arguments Names:
When we declare an argument to a java method, we must provide a name for that argument. This name is used within the method body(local member). The method argument can have the same name as one of the classs member variable. If this is the case, then argument is said to hide the member variable or ambiguous situation. The name of any local variable to the method cannot be same as argument name for the same method. Call: Argument Passing While Method Call: In general, there are two ways that a computer language can pass an argument to a subroutine. The first way is call-by-value. This method copies the value of an argument into the formal parameter of the subroutine. Therefore, changes made to the parameter of the subroutine have no effect on the argument. The second way an argument can be passed is call-by-reference. In this method, a reference to an argument (not the value of the argument) is passed to the parameter. Inside the subroutine, this reference is used to access the actual argument specified in
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 18
the call. This means that changes made to the parameter will affect the argument used to call the subroutine. As you will see, Java uses both approaches, depending upon what is passed. Example : Call By Value: class Test { static void doubleData(int x) { x = x+x; } } class CallByValue { int i; public static void main(String [] ar) { CallByValue ob = new CallByValue(); ob.i = 20; System.out.println("BEFORE : "+ob.i); Test.doubleData(ob.i); System.out.println("AFTER : "+ob.i); }//End Of Main } //End Of CallByValue Reference: Example : Call By Reference: class Test { static void doubleData(CallByReference ob) { ob.i = ob.i + ob.i; } } class CallByReference { int i; public static void main(String [] ar) { CallByReference ob = new CallByReference (); ob.i = 20; System.out.println("BEFORE : "+ob.i); Test.doubleData(ob); System.out.println("AFTER : "+ob.i); }//End Of Main } //End Of CallByValue
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 19
Implementing Inheritance:
There are several ways to implement data structures for inheritance in a non-objectoriented language: it: Avoid it: Many applications do not require inheritance. Many other applications have only a few classes requiring inheritance. Those classes not needing inheritance can be implemented as simple records. Flatten the class hierarchy: Use inheritance during design but expand each concrete class as an independent data structure during implementation. Each inheritance operation must be re-implemented as a separate method on each concrete class. Break out separate object: Instead of inheriting common attribute from a super class, a group of attribute can be pulled out of all the subclasses and implemented as a separate object with a reference to it stored within each subclass. These approaches avoid the implementation of inheritance. When inheritance is actually needed, the best implementation depends on the language.
Implementation Inheritance In C :
To handle single inheritance, embed the declaration for the super class as the first part of each subclass. The class Shape is an abstract class, with concrete sub classes Box and Circle. The C declaration for classes Shape, Box, and Circle are as follows:
struct Shape{ struct ShapeClass *class; Length x; Length y; }; struct Box{ struct BoxClass *class; Length x; Length y;
Length width; Length height; }; struct Circle{ struct CircleClass *class; Length x; Length y; Length radius; };
A pointer to a Box and Circle structure can be passed to a C function expecting a pointer to a Shape structure because the first part of the Box and Circle structure is identical to the Shape structure.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 20
Implementing Association:
Associations are the glue of our object model, providing access paths between objects. During object design phase we must formulate a strategy for implementing the associations in the object model. To make intelligent decision about associations, we first need to analyze the way they are used. Analyzing Association Traversal : We have assumed now that associations are inherently bi-directional, which is certainly true in an abstract sense. But if some associations in our application are only traversed in onedirection, their implementation can be simplified. Types Of Associations :
One-Way Associations : OneIf an association is only traversed in one direction, it may be implemented as a reference in object that is an attribute which contains the reference of an associated object. If the multiplicity is one the it is a simple reference, and if the multiplicity is many then is a collection reference may be Array, ArrayList, Set etc. Two-Way Associations : TwoMany associations are traversed in both directions, although not usually with equal frequency, it may be implemented as attribute in both directions. This approach permits fast access, but if either attribute is updated then the other attribute must also be updated to keep the link consistent.
Implementing Association In Java :
class PersonDetail { Date dob; String address; String contact; String occupation; }
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 21
1) RESUABILITY : Reusable software reduces design, coding, and testing efforts over several design. Reuse is possible in conventional language, but object oriented languages enhance the possibility of code reuse. Types Of Reusability: There are two kinds of reuse : (i) (ii) Sharing of newly-written code. Reuse of previously written code.
Reusabi Style Rules for Reusability: (i) (ii) Keep methods coherent. A method is coherent if it performs a single or a group of closely related functions. Keep methods small. If a method is large, break it into smaller methods. By breaking a method into smaller parts, we may be able to reuse some part even when the entire method is not reusable. (iii) Keep methods consistent. Similar methods should use the uniform consistent. structure including name, condition, arguments order and types, return type and error condition. (iv) Provide Uniform Coverage If input conditions can occur in various combinations, write methods for all combination. Using Inheritance : (i) Subroutine : The simplest approach is to factor out the common code into a single method that is called by each method. Factoring : In some cases the best way to increase code reuse between similar classes is to factor out the differences between the methods of different classes, leaving the remainder of the code as a shared method.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 22
(ii)
2) EXTENSIBILITY : Most software is extended in ways that its original developers may not expect. The following object oriented principles enhance extensibility. Encapsulate Classes : A class is encapsulated if its internal structure is hidden from other classes. Only methods on the class should access its implementation. Hide Data Structure : Do not export data structure from a method. Internal data structures are specific to a methods algorithm. If you export them, you limit flexibility to change the algorithm later. Avoid Case Statement On Object Type : Use method instead. Distinguish public and private Operations : Public operation are visible outside a class and have published interfaces. Once a public operation is used by other classes, it is costly to change its interface, so public operation should me carefully defined. Private operations are internal to a class and are use to help implement the public operation. 3) ROBUSTNESS : A method is robust if it does not fail even if it receives improper parameters. Robustness against internal bugs may be traded off against efficiency. Robustness against user errors should never be sacrificed. Guidelines to design a robust computer application: Protect against errors by validating user input. Perform code optimization after the program runs or start working. Perform argument validation on external operations those available to user of the class to prevent failure. In case of dynamic memory allocation to create data structure we should avoid limits. predefined limits Instruction the program for debugging and performance monitoring.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 23
Programming-InProgramming-In-Large :
Programming in large refers to writing large, complex programs with team of programmers. Human communication becomes paramount on such projects and requires proper software engineering practices. The following guidelines should be observed: not Do not prematurely begin programming All software development methodology emphasis on the importance of first designing, the coding. Keep methods understandable A method is understandable if some other than the creator of the method can understand the code. Make methods readable Meaning full names of methods and its variable increase readability. same Use exactly the same name as in the object model - The choice of name of Classes, method and variable should be exactly same as declared in object model. Documents classes and methods Everything should be documented, class documentation should describe its attributes & methods, and method documentation describes its purpose, functionality, context, input and output. Publish the specification The specification is a contract between the producer and the consumer of class. The specification only contains declarations.
Content Developed by : Mr. Faiz Mohd Arif Khan & Mr. Bhanu Pratap Rai 24