Chapter 1

Download as pdf or txt
Download as pdf or txt
You are on page 1of 6

Object Oriented Programming

Chapter one
Fundamentals of Object-Oriented Programming

1. Introduction
Programming is a creative process carried out by a programmer to instruct a computer
how to do task. Programming paradigm is an approach to solve problem using some
programming language or also we can say it is a method to solve a problem using tools and
techniques that are available to us following some approach. Programming paradigm define how
programmers write or organize the code. There are lots for programming language that are
known but all of them need to follow some strategy when they are implemented and this
methodology/strategy is paradigms. Basically there are two type of programming paradigm
Structured/Procedural Oriented Programming (POP) and Object Oriented Programming (OOP).
With the advent of languages such as C, structured programming became very popular
and was the paradigm of the 1980s. Structured programming is a set of step by step instruction
that the computer must follow. It consisting of a list of instructions organized in the form of
group known as Functions. Structured programming proved to be a powerful tool that enabled
programmers to write moderately complex programs fairly easily. Programs are written in one
long procedure\code. Structured approach gives emphasis to procedure or functions and it share
global data so the data is vulnerable to accidental change. Changes in external data structure lead
to change all the function using it. In this approach it is difficult to make change or add new data
or function. It uses top down approach. Based on security, reusability, expandability, scalability,
maintainability, and flexibility structured approach is failed than OOP.
However, as the program grows larger, even the structured approach failed to show the
desired results in terms of bug –free, easy-to-maintain and reusable programs.
Object-Oriented Programming (OOP) is an approach to program organization and
development, which attempts to eliminate some of the drawbacks of conventional programming
methods by incorporating the best of structured programming features with several new
advanced concepts. It is based on the concept of object. It is a new style of organizing and
developing programs and has nothing to do with any particular. However, not all languages are
suitable to implement the OOP concepts easily. Languages that support OOP features include
C++, C#, Java etc. C++, an extension of C language, is basically a procedural language with
object-oriented extension. The other popular language is Java, which is a pure object-oriented
language.
2. The Object Oriented Paradigm
What is Object Oriented Orientation?
Basically, OOP is a technique of modeling some kind of system in software based Objects.
o It represents a fundamentally different way of thinking about a problem solving than
other software development methodologies.
o It enables us to reduce the software systems complexity and/or failure.
A research made by Standish Group in 1985 says,
 On average only 16.2% of projects are completed on time and with budget.
 31.1% of the projects were cancelled before they ever get completed.
 52.7% of the projects will cost 189% of their original estimate.

1|Page
Object Oriented Programming

OOP treats data as a critical element in the program development and does not allow it to flow
freely around the system. It ties data more closely to the functions that operate on it and protects
it from unintentional modification by other functions. OOP allows us to decompose a problem
into a number of entities called Objects and then build data and functions (known as Methods in
java) around these entities.
The combination of data and methods make up an object (see Fig 1.1)

Method
Method

Data

Method Method

Fig 1.1 Object=data + Methods

The data of an object can be accessed only by the methods associated with that object.
However, methods of one object can access the methods of other objects.

1.1 Features of Object Oriented paradigm (standard)


Programs are divided into
o Interaction of what are known as objects.
o Methods that operate on the data of an object are tied together in the data
structure.
Data is hidden and can not be accessed by external functions.
Emphasis is on data rather than procedures/processes.
Objects may communicate with each other through methods.
Data structures are designed such that they characterize the objects.
New data and methods can be added whenever necessary.
Follows bottom-up approach in program design.

Definition:
OOP: - is an approach that provides a way of modularizing programs by creating
partitioned memory area for both data and methods that can be used as templates for creating
copies of such modules on demand. This means that an object is considered to be a partitioned
area of computer memory that stores data and a set of operations that can that data. Since the
memory partitions are independent, the objects can be used in a variety of different programs
without modification.

1.2 Basic Concepts of Object Oriented Programming

Object
An object is a core concept, and is a model or representation of real-world entity or logical
idea or concept. They are the basic runtime entities in object oriented system. It may

2|Page
Object Oriented Programming

represent a person, a place, a bank account, a table of data or any item that the program may
handle. It may also represent user-defined data types such as vectors and lists. As pointed out
earlier, an object takes up space in the memory and has an associated address like a structure
in C.
When a program is executed, the objects interact by sending messages to one another. For
example lets say ‘customer’ and ‘account’ are two objects in banking program, then the
customer object may send a message to the account object requesting for the balance. Each
object contains data and code to manipulate the data. Objects can interact without having to
know the details of each other’s data or code. It is sufficient to know the type of message
accepted and the type of response returned by the objects.

Class
A class is a design or blue print of a real world entity which defines the core properties
and functions. We just mentioned that objects contain data and code to manipulate that
data. The entire set of data and code of an object can be made a user-defined data type
using concept of a class. A class may be thought of as a ‘data type’ and doesn’t occupy
memory location where as an object as a ‘variable’ of that data type and occupies
memory location for each object except the variable or method is static. Once a class has
been defined, we can create any number of objects belonging to that class. Each object is
associated with the data of type class with which they are created. A class is thus a
collection of objects of similar type. We can’t use class members without object except
the method, variable or block can be declared using static key word. For Example mango,
apple and orange are members of the class fruit.

Definition: A class is a template used to create multiple objects with similar features.

Employee Object
Name
Data
BasicSalary
Salary ()
Methods
Tax()

Fig 1.2 Representation of an Object

Classes are user-defined data types and behave like the built-in data types of a programming
language. For example, the syntax used to create an object is no different than the syntax
used to create an integer object in C++. If Fruit has been defined as a class, then the
statement
Fruit mango; //will create an object mango belonging to the class fruit.

Data Abstraction and Encapsulation

3|Page
Object Oriented Programming

The wrapping (packaging) up of data and methods into a single unit (called class) is
known as encapsulation. Data encapsulation is the most remarkable feature of a class.
The data is not accessible to the outside world and only those methods, which are
wrapped in the class, can access it. This insulation (protecting) of the data from direct
access by the program is called data hiding.
Abstraction:-refers to the act of representing essential features without including
the background details or explanations. Classes use the concept of abstraction and are
defined as a list of abstract attributes such as size, weight, and cost and methods that
operate on these attributes. They encapsulate all essential properties of the objects that are
to be created.

Inheritance
Inheritance is the process by which objects of one class acquire the properties of objects
of another class. Inheritance supports the concept of hierarchical classification. In OOP,
the concept of inheritance provides the idea of reusability. This means that we can add
additional features to an existing class without modifying it. This is possible by deriving
a new class from an existing one. The new class will have the combined features of both
the classes. Thus the real appeal and power of the inheritance mechanism is that it allows
the programmer to reuse a class that is almost, but not exactly, what he wants, and to
tailor the class in such a way that it does not introduce any undesirable side effects into
the rest of the classes.

Polymorphism
Polymorphism means the ability to take more than one form. Same method/function
when applied on different object gives different results. There are two types of
Polymorphism. Compile Time Polymorphism like Method Overloading and Run Time
Polymorphism like Method Overiding. For example, an operation may exhibit different
behavior in different instances. The behavior depends on the type of data used in the
operation.

Shape

Draw ()

Circle object Box object Triangle object

Draw (circle) Draw (box) Draw (triangle)

Fig 1.3 polymorphism

4|Page
Object Oriented Programming

Polymorphism plays an important role in allowing objects having different internal


structure to share the same external interface.

Dynamic Binding
Binding is the association of method call to the method body. It also refers to the
linking of a procedure call to the code to be executed in response to the call. There are
two types of binding. Static binding means the binding of static, private, and final
methods is compile time because these methods can’t be overridden and the type of the
class is determined at the compile time. Dynamic binding means that the code associated
with a given procedure call is not known until the time of the call at run time. This
happens when compiler is not able to resolve the call/binding at compile time. Method
overriding is the best example for Dynamic Binding. It is associated with polymorphism
and inheritance. A procedure call associated with a polymorphic reference depends on the
dynamic type of that reference.
Consider the procedure ‘draw’ in Fig 1.3 above. By inheritance, every object will
have this procedure. Its algorithm is, however, unique to each object and so the draw
procedure will be redefined in each class that defines the object. At run-time, the code
matching the object under current reference will be called.

Message Communication
An object-oriented program consists of a set of objects that communicate with each
other. The process of programming in object-oriented language, therefore, involves the
following three basic steps:
1. Creating classes that define objects and their behavior.
2. Creating objects from class definitions.
3. Establishing communication among objects.

Objects communicate with one another by sending and receiving information much
the same way as people pass messages to one another. A message for an object is a
request for execution of a procedure, and therefore will invoke a method (procedure)
in the receiving object that generates the desired result as shown in Fig 1.4 below.

Sending Receiving
object Message Method () object

Fig 1.4 Message triggers a method

Message passing involves specifying the name of the object, the name of the method
(message) and the information to be sent. For example consider the statement
Employee.Salary (name);
Here, Employee is the object, Salary is the message and name is the parameter that
contains information.

5|Page
Object Oriented Programming

Note: - Objects have life-cycle. They can be created and destroyed. Communication with
an object is feasible as long as it is alive.

1.3 Benefits of Object Oriented Programming


The following are some of the advantages of OOP:
 Through inheritance, we can eliminate redundant code and extend the use of
existing classes.
 We can build programs from the standard working modules that communicate
with one another, rather than having to start writing the code from scratch. This
leads to saving of development time and higher productivity.
 The principle of data hiding helps the programmer to build secure programs that
can not be invaded by code in other parts of the program.
 It is possible to have multiple objects to coexist without any interference.
 It is easy to partition the work in a project based on objects/reducing complexity.
 Object-oriented systems can be easily upgraded from small to large systems.
 Message passing techniques for communication between objects make the
interface descriptions with the external systems much simpler.
 Software complexity can be easily managed.

1.4 Applications of OOP


The promising areas for application of OOP include:
 Simulation and Modeling
 Object-oriented database
 Hypertext and hypermedia
 AI and expert systems.
 Real-time systems
 Decision support and office automation systems.

6|Page

You might also like