Links

অপারেটর অভারলোডিং

আমরা আগের চ্যাপ্টারগুলোতে নানাবিধ অপারেশন দেখেছি - যোগ, বিয়োগ, গুন ভাগ ইত্যাদি । পাইথনের একটা চমৎকার ফিচার হচ্ছে এই অপারেটরগুলোর ফাংশনালিটি পরিবর্তন করা যায় ।
প্রথমেই আমরা দেখে নেই, এই অপারেটর গুলো আসলে কিভাবে কাজ করে । আমরা যখন কোন অপারেটর ব্যবহার করি, যেমন:
a = b + c
পাইথন এই + অপারেশনের ফলাফল নির্নয়ের জন্য ইন্টারনালি b অবজেক্টের __add__ মেথডে আর্গুমেন্ট হিসেবে c কে পাস করে দেয় । ঐ মেথডের রিটার্ন ভ্যালুই হয় উক্ত অপারেশনের ফলাফল । অর্থাৎ, উপরে দেখানো অপারেশনটি আসলে এভাবে কাজ করে -
a = b.__add__(c)
এখানে লক্ষ্য করুন, আপনি যদি এখন এই b অবজেক্টের __add__ মেথডটি পরিবর্তন করে দেন, তাহলে ঐ b অবজেক্টের উপর + অপারেশনের ফাংশনালিটিও পরিবর্তন হয়ে যাচ্ছে ।
এই জিনিসটাই হচ্ছে অপারটের ওভারলোডিং ।
আসুন একটি উদাহরন দেখে নেইঃ
class MyNum():
def __init__(self, value):
self.value = value
def __add__(self, other):
return (self.value * 2) + (other.value * 2)
a = MyNum(2)
b = MyNum(3)
c = a + b
print(c)
উপরের উদাহরণে, MyNum ক্লাস এর ইন্সট্যান্স হিসেবে আমরা দুটো অবজেক্ট তৈরি করলাম এবং এদের প্রত্যেকের value সেট করলাম 2 এবং 3. এরপর এই দুটি অবজেক্টকে সাধারণ যোগ চিহ্ন দিয়ে যোগ করলাম। আমরা চাচ্ছি এই স্পেশাল নাম্বার দুটো একটু আলাদা ভাবে আমাদের নিজেদের মত করে যোগ হয়ে ফিরে আসুক। এক্ষেত্রে, c = a + b লাইনে বস্তুত c = a.__add__(b) স্টেটমেন্টটি এক্সিকিউট হবে। অর্থাৎ a অবজেক্টের __add__ মেথড কল হবে এবং এর মধ্যে প্রথমে 2 এর ভ্যালু দিগুণ হবে, অতঃপর b অবজেক্ট তথা other প্যারামিটার এর value 3 ও দিগুণ হবে। পরিশেষে এদের যোগ ফল রিটার্ন হবে। অর্থাৎ আউটপুট,
10
আরও একটি উদাহরণ দেখে নেইঃ
class MyInt():
def __init__(self, value):
self.__value = value
def __int__(self):
return self.__value
def __add__(self, other):
return self.__value + int(other) * int(other)
a = MyInt(2)
b = MyInt(3)
c = a + b
print(c)
কমন অপারেটর ও তাদের জন্য ব্যবহৃত স্পেশাল মেথড:
  • + => __add__
  • - => __sub__
  • * => __mul__
  • / => __div__
ইনপ্লেইস অপারেটর ওভারলোডিং ইনপ্লেইস অপারেটরগুলোর জন্যও এরকম মেথড রয়েছে । এগুলো হলো:
  • __iadd__
  • __isub__
  • __imul__
  • __idiv__
তাই আর ব্যখ্যায় না গিয়ে কোড দেখে ফেলি:
class MyInt():
def __init__(self, value):
self.__value = value
def __int__(self):
return self.__value
def __iadd__(self, other):
return self.__value + int(other) * int(other)
a = MyInt(2)
a += MyInt(3)
print(a)
কোড রান না করেই আন্দাজ করে বলতে পারবেন আউটপুট কি আসতে পারে?