Skill

অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP)

পাইথন ৩ (Python 3) - Computer Programming

252

অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP) হলো একটি প্রোগ্রামিং প্যারাডাইম যা ডেটা এবং ফাংশনকে একত্রিত করে অবজেক্ট হিসেবে সংগঠিত করে। OOP-তে প্রোগ্রামের নকশা অবজেক্টের চারপাশে তৈরি করা হয়, যা বাস্তব জগতের বিষয়গুলো মডেল করে। OOP-এর মাধ্যমে কোড পুনঃব্যবহারযোগ্যতা, স্থিতিশীলতা এবং মান বজায় রাখা সম্ভব হয়।

OOP-এর প্রধান বৈশিষ্ট্য

অবজেক্ট (Object): অবজেক্ট হলো একটি ডেটা স্ট্রাকচার যা ক্লাসের ইনস্ট্যান্স। এটি ডেটা (অ্যাট্রিবিউট) এবং আচরণ (মেথড) ধারণ করে। উদাহরণস্বরূপ, Car একটি অবজেক্ট হতে পারে যা গতি, রঙ এবং একটি স্টার্ট মেথড ধারণ করে।

ক্লাস (Class): ক্লাস হলো একটি টেমপ্লেট বা ব্লুপ্রিন্ট যা অবজেক্ট তৈরি করে। এটি ডেটা এবং ফাংশনকে সংজ্ঞায়িত করে। উদাহরণস্বরূপ, Car ক্লাসে গতি এবং রঙের মতো অ্যাট্রিবিউট থাকবে এবং চলতে থাকা মেথড থাকবে।

class Car:
    def __init__(self, color, speed):
        self.color = color
        self.speed = speed

    def start(self):
        return "Car started."

এনক্যাপসুলেশন (Encapsulation): এনক্যাপসুলেশন হলো ডেটা এবং ফাংশনগুলোকে একত্রে একটি ইউনিটে ধারণ করা। এটি ডেটা লুকিয়ে রাখে এবং শুধুমাত্র নির্দিষ্ট মেথডের মাধ্যমে তাদের অ্যাক্সেস করার অনুমতি দেয়। উদাহরণস্বরূপ:

class BankAccount:
    def __init__(self, balance):
        self.__balance = balance  # প্রাইভেট অ্যাট্রিবিউট

    def deposit(self, amount):
        self.__balance += amount

    def get_balance(self):
        return self.__balance

হেরিটেজ (Inheritance): হেরিটেজ হলো একটি ক্লাসের (সাব ক্লাস) বৈশিষ্ট্য অন্য একটি ক্লাসের (বেস ক্লাস) মাধ্যমে গ্রহণ করার প্রক্রিয়া। এটি কোড পুনঃব্যবহার করতে সাহায্য করে।

class Vehicle:
    def start(self):
        return "Vehicle started."

class Car(Vehicle):  # Car ক্লাস Vehicle ক্লাস থেকে ইনহেরিট করছে
    def honk(self):
        return "Car honks."

পলিমরফিজম (Polymorphism): পলিমরফিজম হলো একই নামের মেথড বিভিন্ন ক্লাসে ভিন্নভাবে কাজ করতে পারে। এটি ভিন্ন অবজেক্টের উপর একই অপারেশন প্রয়োগ করতে সক্ষম।

class Dog:
    def speak(self):
        return "Woof!"

class Cat:
    def speak(self):
        return "Meow!"

def animal_sound(animal):
    print(animal.speak())

dog = Dog()
cat = Cat()
animal_sound(dog)  # আউটপুট: Woof!
animal_sound(cat)  # আউটপুট: Meow!

OOP-এর সুবিধা

  • কোড পুনঃব্যবহার: ইনহেরিটেন্সের মাধ্যমে কোড পুনঃব্যবহার করা যায়।
  • স্থিতিশীলতা: কোডের সমস্যা বা ত্রুটি সহজে চিহ্নিত এবং সমাধান করা যায়।
  • সংগঠন: কোডের সংগঠন সহজ হয়, কারণ এটি অবজেক্টের মাধ্যমে সজ্জিত হয়।
  • আকর্ষণীয়তা: OOP প্রকল্পগুলোতে বড় আকারের কোড বজায় রাখা সহজ হয়।

সারসংক্ষেপ

অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP) একটি শক্তিশালী প্রোগ্রামিং প্যারাডাইম যা অবজেক্ট, ক্লাস, ইনহেরিটেন্স, এনক্যাপসুলেশন এবং পলিমরফিজমের উপর ভিত্তি করে গঠিত। এটি কোডের উন্নয়ন, পুনঃব্যবহারযোগ্যতা এবং কার্যকারিতা বৃদ্ধি করে। OOP মূলত বাস্তব জগতের বিভিন্ন বিষয়কে মডেল করতে ব্যবহৃত হয়, যা প্রোগ্রামারদের কাজকে সহজ করে।

Content added By

অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP) এর ক্ষেত্রে ক্লাস এবং অবজেক্ট দুইটি গুরুত্বপূর্ণ মৌলিক ধারণা। এখানে আমরা এগুলোর সম্পর্কে বিস্তারিত আলোচনা করব।


ক্লাস (Class)

ক্লাস হল একটি কাঠামো যা একটি নতুন ডেটা টাইপ তৈরির জন্য ব্যবহৃত হয়। এটি অবজেক্টের বৈশিষ্ট্য (এট্রিবিউট) এবং আচরণ (মেথড) সংজ্ঞায়িত করে। ক্লাসগুলির মাধ্যমে আমরা কিভাবে বিভিন্ন অবজেক্ট তৈরি করব এবং তাদের মধ্যে তথ্য আদান-প্রদান করব তা নিয়ন্ত্রণ করতে পারি।

ক্লাসের গঠন

একটি ক্লাস সাধারণত নিচের অংশগুলো অন্তর্ভুক্ত করে:

এট্রিবিউট (Attributes):

  • ক্লাসের অবজেক্টের বৈশিষ্ট্য বা গুণাবলী। এগুলো প্রায়ই ডেটা ফিল্ড বা প্রপার্টি হিসাবেও পরিচিত।
  • উদাহরণ: একটি Car ক্লাসের color, model, এবং speed এট্রিবিউট হতে পারে।

মেথড (Methods):

  • ক্লাসের অবজেক্টের আচরণ বা কার্যকলাপ। মেথডগুলি ফাংশনের মতো কাজ করে যা ক্লাসের অভ্যন্তরে ডিফাইন করা হয়।
  • উদাহরণ: start(), stop(), accelerate() মেথডগুলি গাড়ির আচরণ নির্দেশ করে।

উদাহরণ

class Car:
    def __init__(self, color, model):
        self.color = color  # এট্রিবিউট: রঙ
        self.model = model  # এট্রিবিউট: মডেল
        self.speed = 0      # এট্রিবিউট: গতি

    def start(self):
        print(f"{self.model} is starting.")

    def accelerate(self, increment):
        self.speed += increment
        print(f"{self.model} is now going at {self.speed} km/h.")

    def stop(self):
        self.speed = 0
        print(f"{self.model} has stopped.")

অবজেক্ট (Object)

অবজেক্ট হল ক্লাসের একটি নির্দিষ্ট ইনস্ট্যান্স। যখন আমরা একটি ক্লাসের ভিত্তিতে একটি অবজেক্ট তৈরি করি, তখন আমরা সেই ক্লাসে সংজ্ঞায়িত বৈশিষ্ট্য ও আচরণগুলিকে ব্যবহার করতে পারি। প্রতিটি অবজেক্ট আলাদা ডেটা ধারণ করে এবং আলাদা আলাদা অবস্থায় থাকতে পারে।

অবজেক্ট তৈরির প্রক্রিয়া

  • ইনস্ট্যান্সিয়েশন:
    • ক্লাসের একটি নতুন অবজেক্ট তৈরি করা।
    • Car ক্লাসের একটি অবজেক্ট তৈরি করার জন্য আমরা নিচের কোড ব্যবহার করব:
my_car = Car("Red", "Toyota")
  • অবজেক্টের মাধ্যমে মেথড কল করা:
    • অবজেক্টের মেথড কল করে আমরা তাদের আচরণ কার্যকর করতে পারি।
my_car.start()  # Output: Toyota is starting.
my_car.accelerate(50)  # Output: Toyota is now going at 50 km/h.
my_car.stop()  # Output: Toyota has stopped.

ক্লাস এবং অবজেক্টের মধ্যে সম্পর্ক

  1. এতিহ্য (Inheritance):
    • একটি ক্লাস অন্য ক্লাস থেকে বৈশিষ্ট্য ও আচরণ গ্রহণ করতে পারে। উদাহরণস্বরূপ, একটি ElectricCar ক্লাস Car ক্লাস থেকে ইনহেরিট করে।
class ElectricCar(Car):
    def __init__(self, color, model, battery_size):
        super().__init__(color, model)  # সুপারক্লাসের ইনিশিয়ালাইজার কল করা
        self.battery_size = battery_size

    def charge(self):
        print(f"{self.model} is charging.")

পলিমরফিজম (Polymorphism):

  • একই মেথড নাম বিভিন্ন ক্লাসে বিভিন্নভাবে কাজ করতে পারে। উদাহরণস্বরূপ, start() মেথড Car এবং ElectricCar উভয়েই কাজ করে কিন্তু তাদের আচরণ ভিন্ন হতে পারে।

এনক্যাপসুলেশন (Encapsulation):

  • ক্লাসের মধ্যে ডেটা এবং মেথডগুলিকে একত্রে প্যাকেজ করা হয় এবং বাহিরের অ্যাক্সেস সীমিত করা হয়। উদাহরণস্বরূপ, যদি একটি এট্রিবিউট প্রাইভেট হয় (যেমন: self.__battery_level), তাহলে তা ক্লাসের বাইরে থেকে সরাসরি অ্যাক্সেস করা যাবে না।

উপসংহার

ক্লাস এবং অবজেক্ট OOP এর মূল ভিত্তি। ক্লাসের মাধ্যমে একটি টেম্পলেট তৈরি করা হয় এবং অবজেক্ট দ্বারা সেই টেম্পলেটের ভিত্তিতে নতুন ইউনিট তৈরি করা হয়। OOP ব্যবহারের মাধ্যমে প্রোগ্রামগুলি সংগঠিত, পুনর্ব্যবহারযোগ্য এবং সহজে পরিচালনাযোগ্য হয়। এর ফলে বড় সফটওয়্যার প্রকল্পগুলি আরও কার্যকরী এবং সুষ্ঠুভাবে পরিচালিত হয়।

Content added By

ইনক্যাপসুলেশন (Encapsulation)

ইনক্যাপসুলেশন হল অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP) এর একটি মৌলিক ধারণা, যা ডেটা এবং মেথডগুলিকে একত্রিত করে একটি ক্লাসের মধ্যে প্যাকেজ করে। এটি ডেটার সুরক্ষা এবং নিরাপত্তা বৃদ্ধি করে, কারণ এটি ক্লাসের বাইরের কোড থেকে ডেটার সরাসরি অ্যাক্সেস সীমিত করে। ইনক্যাপসুলেশনের মাধ্যমে, শুধুমাত্র ক্লাসের মেথডগুলির মাধ্যমে ডেটা পরিবর্তন এবং অ্যাক্সেস করা সম্ভব হয়, যা ডেটার অখণ্ডতা রক্ষা করে।

ইনক্যাপসুলেশনের সুবিধা:

  1. ডেটা সুরক্ষা: ক্লাসের ভিতরে থাকা ডেটা বাহিরের কোড দ্বারা পরিবর্তন করা যায় না।
  2. এবস্ট্রাকশন: ব্যবহারকারীরা ডেটার কার্যকারিতা বুঝতে পারে, কিন্তু তার অভ্যন্তরীণ কাজকর্ম জানার প্রয়োজন নেই।
  3. সহজ রক্ষণাবেক্ষণ: ক্লাসের ভিতরের ডেটা পরিবর্তন করা হলে, বাহ্যিক কোডে পরিবর্তন করার প্রয়োজন হয় না।

উদাহরণ:

class BankAccount:
    def __init__(self, owner, balance=0):
        self.owner = owner
        self.__balance = balance  # প্রাইভেট এট্রিবিউট

    def deposit(self, amount):
        if amount > 0:
            self.__balance += amount
            print(f"{amount} deposited. New balance: {self.__balance}")
        else:
            print("Deposit amount must be positive.")

    def withdraw(self, amount):
        if 0 < amount <= self.__balance:
            self.__balance -= amount
            print(f"{amount} withdrawn. Remaining balance: {self.__balance}")
        else:
            print("Invalid withdrawal amount.")

    def get_balance(self):
        return self.__balance  # প্রাইভেট এট্রিবিউটের অ্যাক্সেস প্রদান

# ব্যবহার
account = BankAccount("Alice", 1000)
account.deposit(500)      # Output: 500 deposited. New balance: 1500
account.withdraw(200)     # Output: 200 withdrawn. Remaining balance: 1300
print(account.get_balance())  # Output: 1300

অ্যাক্সেস মডিফায়ার (Access Modifiers)

অ্যাক্সেস মডিফায়ার হল ক্লাসের এট্রিবিউট এবং মেথডগুলির অ্যাক্সেস স্তর নির্ধারণ করার জন্য ব্যবহৃত কীওয়ার্ড। সাধারণত তিন ধরনের অ্যাক্সেস মডিফায়ার ব্যবহার করা হয়:

প্রাইভেট (Private):

  • প্রাইভেট সদস্যরা ক্লাসের বাইরের কোড দ্বারা সরাসরি অ্যাক্সেস করা যায় না। প্রাইভেট সদস্য চিহ্নিত করার জন্য ক্লাসের নামের আগে দুইটি আন্ডারস্কোর (__) ব্যবহার করা হয়।
  • উদাহরণ: self.__balance

প্রোটেক্টেড (Protected):

  • প্রোটেক্টেড সদস্যরা একক আন্ডারস্কোর (_) দিয়ে চিহ্নিত করা হয় এবং এই সদস্যদের ক্লাস এবং তার সাবক্লাস দ্বারা অ্যাক্সেস করা যায়।
  • উদাহরণ: self._protected_variable

পাবলিক (Public):

  • পাবলিক সদস্যদের জন্য কোন বিশেষ চিহ্ন ব্যবহার করা হয় না। এগুলি ক্লাসের বাইরের কোড দ্বারা সহজেই অ্যাক্সেস করা যায়।
  • উদাহরণ: self.owner

উদাহরণ:

class Animal:
    def __init__(self, name):
        self.name = name          # পাবলিক
        self._species = "Unknown" # প্রোটেক্টেড
        self.__age = 0           # প্রাইভেট

    def set_age(self, age):
        if age >= 0:
            self.__age = age
        else:
            print("Age cannot be negative.")

    def get_info(self):
        return f"Name: {self.name}, Species: {self._species}, Age: {self.__age}"

# ব্যবহার
dog = Animal("Buddy")
dog.set_age(5)
print(dog.get_info())  # Output: Name: Buddy, Species: Unknown, Age: 5

উপসংহার

ইনক্যাপসুলেশন এবং অ্যাক্সেস মডিফায়ারগুলি OOP এর মূল ভিত্তি। এগুলি ডেটার সুরক্ষা, পরিষ্কার কোড, এবং রক্ষণাবেক্ষণ সুবিধা প্রদান করে। এই ধারণাগুলির মাধ্যমে প্রোগ্রামগুলি আরও নিরাপদ এবং কার্যকরী হয়। OOP তে ইনক্যাপসুলেশন ব্যবহারের ফলে ডেটা এবং মেথডগুলির মধ্যে একটি স্বচ্ছ সীমারেখা তৈরি হয়, যা সফটওয়্যার ডেভেলপমেন্টকে সহজতর করে।

Content added By

ইনহেরিটেন্স (Inheritance) হলো অবজেক্ট-ওরিয়েন্টেড প্রোগ্রামিংয়ের একটি মূল ধারণা, যা একটি ক্লাসকে (সাব ক্লাস) অন্য একটি ক্লাসের (বেস ক্লাস) বৈশিষ্ট্য এবং আচরণ গ্রহণ করার অনুমতি দেয়। এটি কোড পুনঃব্যবহার এবং জটিলতা হ্রাস করতে সাহায্য করে। ইনহেরিটেন্সের মাধ্যমে একটি ক্লাসের সব ফাংশনালিটি অন্য ক্লাসে পাওয়া যায়।

ইনহেরিটেন্সের প্রকারভেদ

সিঙ্গেল ইনহেরিটেন্স: একটি সাব ক্লাস একটি একক বেস ক্লাস থেকে বৈশিষ্ট্য গ্রহণ করে।

class Animal:
    def speak(self):
        return "Animal speaks"

class Dog(Animal):  # Dog ক্লাস Animal ক্লাস থেকে ইনহেরিট করছে
    def bark(self):
        return "Dog barks"

my_dog = Dog()
print(my_dog.speak())  # আউটপুট: Animal speaks
print(my_dog.bark())   # আউটপুট: Dog barks

মাল্টিপল ইনহেরিটেন্স: একটি সাব ক্লাস একাধিক বেস ক্লাস থেকে বৈশিষ্ট্য গ্রহণ করে।

class Parent1:
    def method1(self):
        return "Method from Parent1"

class Parent2:
    def method2(self):
        return "Method from Parent2"

class Child(Parent1, Parent2):  # Child ক্লাস Parent1 এবং Parent2 থেকে ইনহেরিট করছে
    def method3(self):
        return "Method from Child"

my_child = Child()
print(my_child.method1())  # আউটপুট: Method from Parent1
print(my_child.method2())  # আউটপুট: Method from Parent2
print(my_child.method3())  # আউটপুট: Method from Child

মাল্টি-লেভেল ইনহেরিটেন্স: একটি সাব ক্লাস অন্য একটি সাব ক্লাস থেকে ইনহেরিট করে।

class Animal:
    def speak(self):
        return "Animal speaks"

class Dog(Animal):  # Dog ক্লাস Animal ক্লাস থেকে ইনহেরিট করছে
    def bark(self):
        return "Dog barks"

class Puppy(Dog):  # Puppy ক্লাস Dog ক্লাস থেকে ইনহেরিট করছে
    def weep(self):
        return "Puppy weeps"

my_puppy = Puppy()
print(my_puppy.speak())  # আউটপুট: Animal speaks
print(my_puppy.bark())   # আউটপুট: Dog barks
print(my_puppy.weep())   # আউটপুট: Puppy weeps

হায়ারার্কিক্যাল ইনহেরিটেন্স: একাধিক সাব ক্লাস একটি একক বেস ক্লাস থেকে ইনহেরিট করে।

class Animal:
    def speak(self):
        return "Animal speaks"

class Dog(Animal):  # Dog ক্লাস Animal ক্লাস থেকে ইনহেরিট করছে
    def bark(self):
        return "Dog barks"

class Cat(Animal):  # Cat ক্লাস Animal ক্লাস থেকে ইনহেরিট করছে
    def meow(self):
        return "Cat meows"

my_cat = Cat()
print(my_cat.speak())  # আউটপুট: Animal speaks
print(my_cat.meow())   # আউটপুট: Cat meows

ইনহেরিটেন্সের সুবিধা

কোড পুনঃব্যবহার: ইনহেরিটেন্সের মাধ্যমে পূর্ববর্তী ক্লাসের কোড পুনরায় ব্যবহার করা যায়, যা কোড লেখার সময় সাশ্রয় করে।

গঠনগত সংগঠন: এটি কোডকে আরও সংগঠিত এবং সহজে মেইনটেইনেবল করে তোলে।

পলিমরফিজম: ইনহেরিটেন্সের মাধ্যমে পলিমরফিজম (একাধিক ফর্ম) বাস্তবায়ন করা যায়, যেখানে একটি ফাংশন বিভিন্ন উপায়ে আচরণ করতে পারে।

সারসংক্ষেপ

ইনহেরিটেন্স হল অবজেক্ট-ওরিয়েন্টেড প্রোগ্রামিংয়ের একটি গুরুত্বপূর্ণ ধারণা, যা কোড পুনঃব্যবহার এবং সংস্থাপনে সাহায্য করে। এটি সাব ক্লাসকে বেস ক্লাসের বৈশিষ্ট্য এবং আচরণ গ্রহণের অনুমতি দেয় এবং কোডের সংগঠন এবং মেইনটেইনেবিলিটি বাড়ায়।

Content added By

পলিমরফিজম হল অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP) এর একটি গুরুত্বপূর্ণ ধারণা, যা একাধিক অবজেক্টের জন্য একই নামের মেথড ব্যবহার করতে দেয়, কিন্তু তাদের কার্যকরী আচরণ ভিন্ন হয়। এটি বিভিন্ন ক্লাসের অবজেক্টগুলিকে একত্রে ব্যবহার করার সময় প্রোগ্রামের স্থিতিশীলতা এবং সুবিধা বৃদ্ধি করে।

পলিমরফিজমের ধরন

পলিমরফিজম প্রধানত দুই ধরনের হয়:

কম্পাইল টাইম পলিমরফিজম (Compile-time Polymorphism):

  • এটি মেথড ওভারলোডিং (Method Overloading) এবং অপারেটর ওভারলোডিং (Operator Overloading) এর মাধ্যমে অর্জিত হয়।
  • মেথড ওভারলোডিংয়ের মাধ্যমে একটি ক্লাসে একই নামের কিন্তু বিভিন্ন প্যারামিটার টাইপ বা সংখ্যা বিশিষ্ট মেথড তৈরি করা হয়।
  • অপারেটর ওভারলোডিংয়ের মাধ্যমে মৌলিক অপারেটরগুলির (যেমন: +, -, *, /) ব্যবহারিক আচরণ পরিবর্তন করা হয়।

রানটাইম পলিমরফিজম (Runtime Polymorphism):

  • এটি মেথড ওভাররাইডিং (Method Overriding) এর মাধ্যমে অর্জিত হয়, যেখানে সাবক্লাস সুপারক্লাসের মেথডকে পুনঃসংজ্ঞায়িত করে।
  • এটি সাধারণত অভ্যন্তরীণ সম্পর্কযুক্ত ক্লাসের মধ্যে ঘটে।

উদাহরণ

১. কম্পাইল টাইম পলিমরফিজম (মেথড ওভারলোডিং)

class MathOperations:
    def add(self, a, b):
        return a + b

    def add(self, a, b, c):
        return a + b + c

# অবজেক্ট তৈরি করা
math_op = MathOperations()

# প্রথম দুটি প্যারামিটার নিয়ে ব্যবহার করা
result1 = math_op.add(5, 10)  # এর জন্য SyntaxError হবে
print(result1)

# তিনটি প্যারামিটার নিয়ে ব্যবহার করা
result2 = math_op.add(5, 10, 15)
print(result2)  # Output: 30

নোট: পিথনের মতো ভাষায় মেথড ওভারলোডিং সঠিকভাবে কাজ না করতে পারে। তবে আমরা অন্য প্যারামিটার ব্যবহার করে পলিমরফিজম অর্জন করতে পারি।

২. রানটাইম পলিমরফিজম (মেথড ওভাররাইডিং)

class Animal:
    def sound(self):
        return "Animal sound"

class Dog(Animal):
    def sound(self):
        return "Bark"

class Cat(Animal):
    def sound(self):
        return "Meow"

# অবজেক্ট তৈরি করা
animals = [Dog(), Cat()]

for animal in animals:
    print(animal.sound())

আউটপুট:

Bark
Meow

এখানে Dog এবং Cat ক্লাস দুটি আলাদা আচরণ (মেথড) সরবরাহ করে, যদিও তারা একই নামের sound() মেথড ব্যবহার করছে। এটি রানটাইম পলিমরফিজমের একটি উদাহরণ।

পলিমরফিজমের সুবিধা

  1. কোড পুনর্ব্যবহারযোগ্যতা: একই মেথড নাম ব্যবহার করে বিভিন্ন ক্লাসের অবজেক্টকে পরিচালনা করা যায়।
  2. স্থিতিশীলতা: পরিবর্তনের ফলে কোডের বাকি অংশে প্রভাব কম হয়।
  3. সুবিধাজনক ডেভেলপমেন্ট: কোডের সংগঠন উন্নত হয়, যা ডেভেলপমেন্টকে সহজ করে।

উপসংহার

পলিমরফিজম OOP এর একটি মৌলিক ধারণা যা প্রোগ্রামিংয়ের জন্য ক্ষমতা এবং নমনীয়তা বৃদ্ধি করে। এটি আমাদের একই নামের মেথডের বিভিন্ন বাস্তবায়ন করতে দেয়, যা কোডের পুনর্ব্যবহারযোগ্যতা এবং স্থিতিশীলতা নিশ্চিত করে। OOP এ পলিমরফিজমের ব্যবহার সফটওয়্যার ডেভেলপমেন্টকে আরও কার্যকরী ও সুবিধাজনক করে তোলে।

Content added By

ম্যাজিক মেথড এবং ওভারলোডিং দুইটি গুরুত্বপূর্ণ ধারণা যা অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিং (OOP) এ ব্যবহৃত হয়। এগুলি মূলত ক্লাসের কার্যকারিতা বাড়াতে সাহায্য করে। আসুন আমরা প্রতিটি ধারণার বিস্তারিত আলোচনা করি।

ম্যাজিক মেথড (Magic Methods)

ম্যাজিক মেথড হল পূর্বনির্ধারিত বিশেষ মেথড যা Python এবং অন্যান্য কিছু OOP ভাষায় ব্যবহৃত হয়। এগুলি সাধারণত ডাবল আন্ডারস্কোর (__) দিয়ে চিহ্নিত করা হয় এবং ক্লাসের অবজেক্টের বিভিন্ন আচরণ এবং কার্যকলাপ নিয়ন্ত্রণ করতে ব্যবহৃত হয়। ম্যাজিক মেথডগুলি স্বয়ংক্রিয়ভাবে কখনও কখনও ক্লাসের অবজেক্টের সাথে সংযুক্ত হয়।

সাধারণ ম্যাজিক মেথডের উদাহরণ

  • __init__: কনস্ট্রাক্টর, যা অবজেক্ট তৈরি করার সময় ডেটা ইনিশিয়ালাইজ করে।
  • __str__: অবজেক্টের স্ট্রিং উপস্থাপনাকে নিয়ন্ত্রণ করে, যখন print() ফাংশন ব্যবহার করা হয়।
  • __repr__: অবজেক্টের অফিসিয়াল স্ট্রিং উপস্থাপনাকে নিয়ন্ত্রণ করে, যা ডেভেলপারদের জন্য ব্যবহারিক।
  • __add__: প্লাস অপারেটর (+) ব্যবহারের সময় আচরণ নিয়ন্ত্রণ করে।
  • __len__: len() ফাংশনের সময় আচরণ নিয়ন্ত্রণ করে।

 

__init__: কনস্ট্রাক্টর, যা অবজেক্ট তৈরি করার সময় কল হয়।

class Person:
    def __init__(self, name):
        self.name = name

person = Person("Alice")
print(person.name)  # আউটপুট: Alice

__str__: অবজেক্টের একটি মানব-পঠনযোগ্য স্ট্রিং রিটার্ন করে।

class Person:
    def __init__(self, name):
        self.name = name
    
    def __str__(self):
        return f"Person: {self.name}"

person = Person("Alice")
print(person)  # আউটপুট: Person: Alice

__add__: দুইটি অবজেক্ট যোগ করার জন্য ব্যবহৃত হয়।

class Number:
    def __init__(self, value):
        self.value = value
    
    def __add__(self, other):
        return Number(self.value + other.value)

num1 = Number(10)
num2 = Number(20)
result = num1 + num2  # __add__ ম্যাজিক মেথড কল হবে
print(result.value)    # আউটপুট: 30

__len__: অবজেক্টের দৈর্ঘ্য ফেরত দেয়।

class MyList:
    def __init__(self, items):
        self.items = items
    
    def __len__(self):
        return len(self.items)

my_list = MyList([1, 2, 3])
print(len(my_list))  # আউটপুট: 3

ওভারলোডিং

ওভারলোডিং হলো একই নামের ফাংশন বা মেথডের একাধিক সংজ্ঞা প্রদান করা, যা বিভিন্ন প্রকার ইনপুট গ্রহণ করে। পাইথনে ক্লাসে মেথড ওভারলোডিং সরাসরি করা সম্ভব নয়, তবে আমরা আর্গুমেন্টের সংখ্যা এবং টাইপের ভিত্তিতে একই নামের ফাংশন তৈরি করতে পারি।

উদাহরণ:

class Math:
    def add(self, a, b):
        return a + b
    
    def add(self, a, b, c):  # একই নামের মেথড
        return a + b + c

math = Math()
print(math.add(5, 10))        # আউটপুট: TypeError: add() missing 1 required positional argument: 'c'
print(math.add(5, 10, 15))    # আউটপুট: 30

পাইথনে, দ্বিতীয় add মেথডটি প্রথমটিকে ওভাররাইট করে, তাই এটি কাজ করবে না। তবে, মেথড ওভারলোডিং অর্জন করতে আমরা প্যারামিটারের সংখ্যা চেক করতে পারি।

সঠিক উদাহরণ:

class Math:
    def add(self, *args):  # ভ্যারিয়েবল লেন্থ আর্গুমেন্ট
        return sum(args)

math = Math()
print(math.add(5, 10))        # আউটপুট: 15
print(math.add(5, 10, 15))    # আউটপুট: 30

সারসংক্ষেপ

  • ম্যাজিক মেথড: ক্লাসের বিশেষ ধরনের মেথড যা অবজেক্টের আচরণ কাস্টমাইজ করে এবং বিশেষ পরিস্থিতিতে কল হয়।
  • ওভারলোডিং: একই নামের ফাংশনের একাধিক সংজ্ঞা, যা বিভিন্ন আর্গুমেন্ট গ্রহণ করে। পাইথনে সরাসরি ওভারলোডিং সম্ভব নয়, তবে ভ্যারিয়েবল লেন্থ আর্গুমেন্ট ব্যবহার করে এটি অর্জন করা যায়।

এটি ক্লাসের কার্যকারিতা এবং আচরণকে কাস্টমাইজ করতে সাহায্য করে এবং অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিংয়ের একটি গুরুত্বপূর্ণ অংশ।

Content added By
Promotion

Are you sure to start over?

Loading...