Python journey | Day 7
On Day 7 let's delve into the basics of Object-Oriented Programming (OOP), covering classes, objects, attributes, methods, inheritance, and polymorphism.
Classes and Objects:
Classes:
A class is a blueprint or template for creating objects. It defines the properties (attributes) and behaviors (methods) that objects of that class will have.
class Car:
# Attributes
def __init__(self, make, model, year):
self.make = make
self.model = model
self.year = year
# Methods
def info(self):
return f"{self.year} {self.make} {self.model}"
Objects:
An object is an instance of a class. It's created based on the blueprint provided by the class.
car1 = Car("Toyota", "Corolla", 2023)
car2 = Car("BMW", "X5", 2022)
print(car1.info()) # Output: 2023 Toyota Corolla
print(car2.info()) # Output: 2022 BMW X5
Inheritance and Polymorphism:
Inheritance:
Inheritance allows a new class (child class) to inherit properties and behavior from another class (parent or base class). It promotes code reuse and the creation of hierarchical relationships.
class ElectricCar(Car):
def __init__(self, make, model, year, battery):
super().__init__(make, model, year)
self.battery = battery
def electric_info(self):
return f"{self.info()} with {self.battery} kWh battery"
Here, ElectricCar is inheriting the Car class.
electric_car = ElectricCar("Tesla", "Model S", 2023, 100)
print(electric_car.electric_info()) # Output: 2023 Tesla Model S with 100 kWh battery
Polymorphism:
Polymorphism allows objects to be treated as instances of their parent class, providing a way to use different classes through a uniform interface.
def get_car_info(car):
print(car.info())
get_car_info(car1) # Output: 2023 Toyota Corolla
get_car_info(electric_car) # Output: 2023 Tesla Model S
Both car1 and electric_car are treated as 'Cars' when passed to get_car_info(), even though electric_car is an instance of the ElectricCar class, demonstrating polymorphism.
Recommended by LinkedIn
Let's see some additional topics and best practices on Object-Oriented Programming concepts:
Encapsulation:
Encapsulation refers to the bundling of data (attributes) and methods that operate on the data within a class. It helps in controlling access to the inner workings of the object and protects the data from external interference.
Example:
class BankAccount:
def __init__(self, account_number, balance):
self.account_number = account_number
self.__balance = balance # Private attribute
def get_balance(self):
return self.__balance
def deposit(self, amount):
# Perform validation or other operations here
self.__balance += amount
def withdraw(self, amount):
# Perform validation or other operations here
if amount <= self.__balance:
self.__balance -= amount
else:
print("Insufficient funds")
Abstraction:
Abstraction focuses on hiding complex implementation details and showing only the necessary features of an object. It allows you to work at a higher level of understanding.
Example:
from abc import ABC, abstractmethod
class Shape(ABC):
@abstractmethod
def area(self):
pass
class Circle(Shape):
def __init__(self, radius):
self.radius = radius
def area(self):
return 3.14 * self.radius * self.radius
class Rectangle(Shape):
def __init__(self, width, height):
self.width = width
self.height = height
def area(self):
return self.width * self.height
Method Overriding:
This allows a subclass to provide a specific implementation of a method that is already provided by its parent class.
Example:
class Animal:
def sound(self):
print("Some generic sound")
class Dog(Animal):
def sound(self):
print("Bark")
class Cat(Animal):
def sound(self):
print("Meow")
Composition over Inheritance:
Sometimes, it's more advantageous to use composition (having an instance of another class within a class) rather than inheritance. It can lead to more flexible and maintainable code.
Example:
class Engine:
def start(self):
print("Engine started")
class Car:
def __init__(self):
self.engine = Engine()
def start(self):
self.engine.start()
Understanding these concepts enhances your ability to design and implement more robust and efficient object-oriented systems. Each concept has its place and offers various advantages depending on the problem you're solving and the structure of your program. They allow for efficient code organization, re-usability, and readability.