OOP
Object-oriented programming, or OOPs, is a programming paradigm that implements the concept
of objects in the program. It aims to provide an easier solution to real-world problems by implementing
real-world entities such as inheritance, abstraction, polymorphism, etc. in programming. OOPs concept
is widely used in many popular languages like Java, Python, C++, etc.
1. What is Object Oriented Programming (OOP)?
Object Oriented Programming (also known as OOP) is a programming paradigm where the complete
software operates as a bunch of objects talking to each other. An object is a collection of data and the
methods which operate on that data. Also, it is associated by the following concepts:
2. Why OOP?
The main advantage of OOP is better manageable code that covers the following:
1. The overall understanding of the software is increased as the distance between the language
spoken by developers and that spoken by users.
2. Object orientation eases maintenance by the use of encapsulation. One can easily change the
underlying representation by keeping the methods the same.
3. The OOPs paradigm is mainly useful for relatively big software.
3. What is a Class?
A class is a building block of Object-Oriented Programs. It is a user-defined data type that contains the
data members and member functions that operate on the data members. It is like a blueprint or
template of objects having common properties and methods.
4. What is an Object?
An object is an instance of a class. Data members and methods of a class cannot be used directly. We
need to create an instance or methods of the class to use them. In simple terms, they are the actual
world entities that have a state and behavior.
Syntax
class class_name: class oop:
data_members id = 123
methods name = “OOP”
def display(self):
print(“name”,self.name)
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
self
1. Class methods must have an extra first parameter in the method definition. We do not give a
value for this parameter when we call the method.
2. If we have a method that takes no arguments, then we still have to have one argument.
3. This is similar to these pointers in C++ and this reference in Java.
Creating instance:
instance_name = class_name() e = emp()
*to call data member and methods:
print(e.id)
print(e.name)
e.disp()
The __init__ function
The __init__() function is a built-in function which is executed when the class is being initiated.
This function assign values to object properties, or other operations that are necessary to the object.
Also, this function is called automatically every time the class is being used. It takes two parameters:
self (referring to the instance being created) and name (representing the name of the dog). The name
parameter is used to assign a name of the attribute to each instance of the class. The method is defined
within the class. This method prints the values that includes the attributes of the class instance. For
example:
class Person:
def __init__(self, name, age): Output:
self.name = name Jerico
self.age = age 24
p1 = Person("Jerico", 24)
print(p1.name)
print(p1.age)
Methods
Objects contains methods that are functions belonging to an object.
class Person:
def __init__(self, name, age):
self.name = name
self.age = age
def myfunc(self):
print("Hello my name is " + self.name)
p1 = Person("Jerico", 24)
p1.myfunc()
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
CONSTRUCTORS AND DESTRUCTORS
Constructors Destructors
- By defining __init__
- Parameterized/non parameterized - Destructors are called when an object
gets destroyed using the __del__ method
which is known as a destructor method.
Ex.
class A: class A:
def __init__(self):
print(“constructor”) def __init__(self):
def __init__(self,name,id):
self.id = id; print(‘Class Employee has been
self.name = name; created.’) #Initialization
def __del__(self):
print(‘Destructor called, Class
Employee deleted.’)
obj = A()
del obj
There are 4 principles of OOP which is also known as the 4 pillars of OOP
- Encapsulation
- Abstraction
- Inheritance
- Polymorphism
1. Encapsulation
Encapsulation is the binding of data and methods that manipulate them into a single unit such that the
sensitive data is hidden from the users
It is implemented as the processes mentioned below:
Data hiding: A language feature to restrict access to members of an object. For example, private
and protected members in an object.
Bundling of data and methods together: Data and methods that operate on that data are
bundled together. For example, the data members and member methods that operate on them
are wrapped into a single unit known as a class presented in the figure below:
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
Figure 1: Encapsulation
Source: www.geeksforgeeks.org
Simply, encapsulation is the technique of making the fields in a class private and providing access to the
field via public methods. Also, it can be described as a protective barrier that prevents the code and data
being randomly accessed by other code defined outside the class.
We can restrict access to methods and variables. This prevents data from direct modification which is
called encapsulation. To achieve this, we denote private attributes and define setter method to access
this only.
Example of implementing Encapsulation:
class computer:
__modelname = “Predator Helios 300”
__price = 86000
__newprice = 62000
def sellPrice(self):
print(“Model: {} Price: {}”.format(self.__modelname, sefl.__newprice))
def setNewPrice(self,newP):
self.__newprice = newP
c = computer()
c.sellPrice()
c.__newprice = 50000
c.sellPrice()
c.setNewPrice(50000)
c.sellPrice()
2. Abstraction
Abstraction is similar to data encapsulation and is very important in OOP. It means showing only the
necessary information and hiding the other irrelevant information from the user. Abstraction is
implemented using classes and interfaces.
Figure 2: Abstraction
Source: www.geeksforgeeks.org
Abstraction means hiding the complexity of the object and show only the essential features of the
object. So, in a way, abstraction means hiding the real implementation of an application from the user
and emphasizing only on how to use it.
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
The primary focus of abstraction is to hide the internal implementations of a process or method from
the user. In this way, the user knows what he is doing but not how the work is being done. For example,
a user sees a car containing 4 wheels, a maneuver, and a windshield. The user drives knowing the
complexity of the parts which will form a car.
Example of Implementing Abstraction:
class Rectangle:
def __init__(self, length, width):
self.__length = length # Private attribute
self.__width = width # Private attribute
def area(self):
return self.__length * self.__width
def perimeter(self):
return 2 * (self.__length + self.__width)
rect = Rectangle(5, 3)
print(f"Area: {rect.area()}") # Output: Area: 15
print(f"Perimeter: {rect.perimeter()}") # Output: Perimeter: 16
3. Inheritance
Inheritance is one of the most important concepts of OOP. It provides code reusability, readability and
transition of properties which helps in optimized and efficient code building. Additionally, it allows
classes to inherit common properties from other classes like: if there is a class such as ‘vehicle’, other
classes like ‘car’, ‘bike’, etc., can inherit common properties from the vehicle class. This property helps
you get rid of redundant code thereby reducing the overall size of the code.
Inheritance allows us to define a class that inherits all the methods and properties from another class
like:
Parent class – is the class being inherited from, also called base class.
Child class – is the class that inherits from another class, also called derived class.
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
Syntax:
class first_name: #main class
body of the class
class derivedClass(first_class) #sub class
body of derivedClass
Types of Inheritance
One class can hire properties from other class
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
Here’s the example on how to implement Inheritance in Python:
class Animal: #main class
def_ _init_ _(self, name, age):
self.name=name
self.age=age
def eat(self):
print(“The animal is eating…”)
class Dog(Animal): #sub class
def bark(self):
print(“Woof woof!”)
d= Dog(“Rover” , 3)
Print(d.name) #Output: Rover
d.eat() #Output: The animal Is eating
d.bark() #Output:Woof woof!
4. Polymorphism
Polymorphism is made from 2 words – ‘poly’ which means ‘many’ and ‘morphs’ which means ‘many
forms’. To put it simply, polymorphism allows you to do the same activity in a variety of ways.
Figure 4: Polymorphism
Source: www.geeksforgeeks.org
For example, we need to determine if the given species of birds fly or not, using polymorphism we can
do this in a single function. The following code demonstrates the concept of OOP in python and method
overriding in Python classes showing how subclasses can override methods defined in their parent class
to provide specific behavior while still inheriting other methods from the parent class.
class departments():
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
def bsit(self):
print("BSIT department.")
def bsoa(self):
print("BSOA department.")
def bsba(self):
print("BSBA department.")
class courses():
def bsit(self):
print("BSIT course.")
def bsoa(self):
print("BSOA course.")
def bsba(self):
print("BSBA course.")
dep = departments()
crs = courses()
dep.bsit()
dep.bsoa()
dep.bsba()
crs.bsit()
Modules
Modules in python are files containing a set of functions you may want to include in your application.
These are typically objects created from a file and are accessed by the python interpreter. For instance,
if you quit from the Python interpreter and enter it again, the definitions you have made (functions and
variables) are lost. Therefore, if you want to write a somewhat longer program, you are better off using
a text editor to prepare the input for the interpreter and running it.
This is also known as creating script. As your program gets longer, you may want to split it into several
files for easier maintenance. You may also want to use a handy function that you’ve written in several
programs without copying its definition into each program.
To support this, Python has a way to put definitions in a file and use them in a script or in an interactive
instance of the interpreter. Such a files is called a module; definitions from a module can be imported
into other modules or into the main module.
To create a module as mymodule then save the code in a file with the file extension .py :
def greetings(name):
print(“Hello, “ + name)
Now we can use the module we just created, by using the import statement:
import mymodule
mymodule.greeting(“Jonathan”)
On the other hand, the module can contain functions, as already described, but also variables of all
types (arrays, dictionaries, objects, etc.)
Try to create a module containing the following code:
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82
person = {
“name” : “Jerico”,
“age” : 24,
“address” : “Bontoc”
}
Now save the file with the name mymodule.py
Let us now try to access the module we have created by importing the module named mymodule, and
access the person dictionary:
Import mymodule
a = mymodulle.person[“age”]
print(a)
Prepared by: JERICO F. LIMOG
OOP Instructor
Code: 67, 68, 81, 82