ইনহেরিটেন্স
এই চ্যাপ্টারটি সর্বশেষ হালনাগাদ হয়েছেঃ সময়ে
ইংলিশ শব্দ inheritance এর একটা বাংলা অর্থ হচ্ছে উত্তরাধিকার সূত্রে কিছু পাওয়া। পাইথনে ক্লাস গুলোর মধ্যে কিছু ফাংশনালিটি ও বৈশিষ্ট্য শেয়ার করার একটা পদ্ধতি হচ্ছে ইনহেরিট্যান্স। অর্থাৎ, একটা ক্লাসকে ইনহেরিট (অনুসরণ) করে তার কিছু বৈশিষ্ট্য আরেকটি উত্তরসূরি ক্লাসের মধ্যে নিয়ে আসার ব্যাপারটিকেই ইনহেরিট্যান্স বলা হয়।
আগের চ্যাপ্টারে আমরা একটা ক্লাস দেখেছি Monster. এই ক্লাস থেকে আমরা বিভিন্ন রকম আলাদা আলাদা অবজেক্ট তথা দৈত্য তৈরি করা দেখেছি। একটি ক্লাসে আমরা সেই সব প্রোপার্টি এবং মেথড রাখি যেগুলো এই ক্লাস থেকে বানানো অবজেক্টের কাজে লাগে। কিন্তু যদি এমন হয় যে, Monster ক্লাস থেকে বানানো অবজেক্ট গুলোর আরও নিজস্ব কিছু অ্যাক্টিভিটি (মেথড) দরকার যেগুলো আমাদের Monster ক্লাস বা টেম্পলেটে নাই। তাহলে কি হবে? আমরা কি তবে ওই ক্লাস থেকে অবজেক্ট বানানো বাদ দিয়ে দেবো? আরেকটি ক্লাস বানিয়ে সেই নতুন ক্লাস থেকে অবজেক্ট তথা একটু ভিন্ন বৈশিষ্ট্যের দৈত্য বানানো শুরু করবো?
না। বরং আমরা শুধুমাত্র বাড়তি প্রয়োজনীয় ফিচার গুলো নিয়ে একটি ছোট ক্লাস বানাবো ঠিকি কিন্তু কমন বৈশিষ্ট্য গুলোর সুবিধা নেয়ার জন্য সেই Monster ক্লাসকেই ইনহেরিট করবো।
উদাহরণ,
1
class Monster:
2
def __init__(self, name, color):
3
self.name = name
4
self.color = color
5
6
def attack(self):
7
print('I am attacking...')
8
9
10
class Fogthing(Monster):
11
def make_sound(self):
12
print('Grrrrrrrrrr\n')
13
14
15
class Mournsnake(Monster):
16
def make_sound(self):
17
print('Hiiissssshhhh\n')
18
19
20
fogthing = Fogthing("Fogthing", "Yellow")
21
fogthing.attack()
22
fogthing.make_sound()
23
24
mournsnake = Mournsnake("Mournsnake", "Red")
25
mournsnake.attack()
26
mournsnake.make_sound()
Copied!
ধরে নিচ্ছি আমাদের সব দৈত্যই আক্রমণ করে এবং একটা নাম এবং একরকম রং আছে। তাই এসব মিলে আমরা একটি ব্লুপ্রিন্ট (ক্লাস) বানিয়েছি Monster নামে। এবার সত্যিকারের দৈত্য অবজেক্ট তৈরির সময় মনে হল যে, fogthing আর mournsnake দৈত্যের শব্দ তো আলাদা রকম। তখন আমরা বাড়তি এই ফাংশনটা সহ Fogthing আর Mournsnake নামের দুটো ক্লাস বানিয়ে নিয়েছি কিন্তু সেগুলো মুল Monster ক্লাসকে ইনহেরিট করছে। অর্থাৎ নতুন এই দুটি ক্লাসের নিজস্ব কিছু ফিচার আছে সাথে Monster ক্লাসের সব ফিচারও পাচ্ছে।
আউটপুট,
1
I am attacking...
2
Grrrrrrrrrr
3
4
I am attacking...
5
Hiiissssshhhh
Copied!
কোন ক্লাসকে ইনহেরিট করার জন্য ওই ক্লাসের নামটি নতুন ক্লাসের নামের পর ব্র্যাকেটের মধ্যে লিখতে হয়। এখানে Monster হচ্ছে সুপারক্লাস আর Fogthing, Mournsnake হচ্ছে সাবক্লাস
অভাররাইড যদি সুপারক্লাসের কোন মেথড বা অ্যাট্রিবিউটকে এর একটা সাবক্লাসের মধ্যে আবার ডিফাইন করা হয় তাহলে সেগুলো অভাররাইড হয়ে যায়। যেমন,
1
class Monster:
2
def __init__(self, name, color):
3
self.name = name
4
self.color = color
5
6
def attack(self):
7
print('I am attacking...')
8
9
10
class Fogthing(Monster):
11
def attack(self):
12
print('I am killing...')
13
14
def make_sound(self):
15
print('Grrrrrrrrrr\n')
16
17
18
fogthing = Fogthing("Fogthing", "Yellow")
19
fogthing.attack()
20
fogthing.make_sound()
Copied!
আউটপুট,
1
I am killing...
2
Grrrrrrrrrr
Copied!
উপরের উদাহরণে, Fogthing ক্লাস মুল Monster ক্লাসের attack মেথডকে অভাররাইড করেছে।
মাল্টিপল ইনহেরিট্যান্স নিচের প্রোগ্রামটি দেখি এবং অনুমান করি এর আউটপুট কি আসবে,
1
class A:
2
def where(self):
3
print("I am from class A")
4
5
6
class B:
7
def where(self):
8
print("I am from class B")
9
10
11
class C(A, B):
12
pass
13
14
an_instance_of_c = C()
15
an_instance_of_c.where()
Copied!
এখানে, C ক্লাসটি A এবং B দুটো ক্লাসকেই ইনহেরিট করেছে। আবার ওই দুটো ক্লাসের প্রত্যেকটিতেই where নামের মেথড আছে। পরিশেষে, যখন C ক্লাসের ইন্সট্যান্স তৈরি করে where মেথডকে কল করা হচ্ছে তখন আসলে কোন ক্লাসের where মেথডটি কল হবে? প্রথমেই সেই মেথডকে C ক্লাসের মধ্যে খোঁজা হবে, না পেলে A ক্লাসের মধ্যে আর সেখানেও না পেলে B ক্লাসের মধ্যে খোঁজা হবে। এখন বলা যায় আউটপুট কি আসবে,
1
I am from class A
Copied!
এই অর্ডার ভিত্তিক মেথড খোঁজার জন্য পাইথন নিজস্ব নিয়ম ফলো করে এবং সেটা দেখতে চাইলে আমরা প্রোগ্রামে print(C.mro()) স্টেটমেন্টটি ব্যবহার করতে পারি যার আউটপুট আসবে নিচের মত,
1
[<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>]
Copied!
অর্থাৎ, C, A, B
super মেথড ইনহেরিট্যান্স এর ক্ষেত্রে super একটি গুরুত্বপূর্ণ মেথড। এর মাধ্যমে একটি অবজেক্টের সুপার ক্লাসের মধ্যেকার মেথডকে কল করা যায়। যেমন,
1
class A:
2
def spam(self):
3
print(1)
4
5
class B(A):
6
def spam(self):
7
print(2)
8
super().spam()
9
10
B().spam()
Copied!
আউটপুট,
1
2
2
1
Copied!
Last modified 3yr ago
Copy link