वंशानुक्रम और बहुरूपता
विरासत और बहुरूपता - यह पायथन में एक बहुत महत्वपूर्ण अवधारणा है। यदि आप सीखना चाहते हैं तो आपको इसे बेहतर समझना चाहिए।
विरासत
ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग का एक बड़ा फायदा फिर से उपयोग है। वंशानुक्रम उसी को प्राप्त करने के लिए एक तंत्र है। वंशानुक्रम प्रोग्रामर को पहले एक सामान्य या एक आधार वर्ग बनाने की अनुमति देता है और बाद में इसे और अधिक विशिष्ट वर्ग तक विस्तारित करता है। यह प्रोग्रामर को बेहतर कोड लिखने की अनुमति देता है।
इनहेरिटेंस का उपयोग करके आप अपने बेस क्लास में उपलब्ध सभी डेटा फ़ील्ड और विधियों का उपयोग या इनहेरिट कर सकते हैं। बाद में आप अपने स्वयं के तरीकों और डेटा फ़ील्ड जोड़ सकते हैं, इस प्रकार वंशानुक्रम कोड को व्यवस्थित करने का एक तरीका प्रदान करता है, बजाय इसे खरोंच से फिर से लिखना।
ऑब्जेक्ट-ओरिएंटेड शब्दावली में जब कक्षा X वर्ग Y का विस्तार करता है, तो Y को सुपर / पैरेंट / बेस क्लास कहा जाता है और X को उपवर्ग / चाइल्ड / व्युत्पन्न वर्ग कहा जाता है। यहां ध्यान देने वाली बात यह है कि केवल वे डेटा फ़ील्ड और विधि जो निजी नहीं हैं, वे बाल कक्षाओं द्वारा सुलभ हैं। निजी डेटा फ़ील्ड और विधियाँ केवल कक्षा के अंदर ही पहुँच योग्य हैं।
व्युत्पन्न वर्ग बनाने के लिए वाक्य रचना है -
class BaseClass:
Body of base class
class DerivedClass(BaseClass):
Body of derived class
इन्हेरिटिंग एट्रीब्यूट्स
अब नीचे दिए गए उदाहरण को देखें -
उत्पादन
हमने पहली बार Date नामक एक क्लास बनाई और ऑब्जेक्ट को एक तर्क के रूप में पास किया, यहाँ ऑब्जेक्ट-इन-क्लास बनाया गया है जो पायथन द्वारा प्रदान किया गया है। बाद में हमने टाइम नामक एक और क्लास बनाई और डेट क्लास को एक तर्क के रूप में बुलाया। इस कॉल के माध्यम से हमें दिनांक वर्ग के सभी डेटा और विशेषताओं का समय वर्ग में प्रवेश मिलता है। उसकी वजह से जब हम टाइम क्लास ऑब्जेक्ट tm से get_date मेथड प्राप्त करने का प्रयास करते हैं, जो हमने पहले संभव बनाया था।
ऑब्जेक्ट। लुकअप पदानुक्रम
- उदाहरण है
- कक्षा
- कोई भी वर्ग जिससे यह वर्ग विरासत में मिला है
वंशानुक्रम उदाहरण
आइए विरासत के उदाहरण में एक नज़दीकी नज़र डालें -
आइए उदाहरणों में भाग लेने के लिए कुछ वर्गों का निर्माण करें -
- पशु - वर्ग एक जानवर का अनुकरण करता है
- बिल्ली - पशु का उपवर्ग
- कुत्ता - जानवर का उपवर्ग
पायथन में, क्लास का कंस्ट्रक्टर ऑब्जेक्ट (उदाहरण) बनाने के लिए उपयोग किया जाता है, और विशेषताओं के लिए मूल्य प्रदान करता है।
उपवर्गों के निर्माता को हमेशा मूल वर्ग में विशेषताओं के लिए मूल्य को इनिशियलाइज़ करने के लिए पैरेंट क्लास के एक कंस्ट्रक्टर के पास बुलाया जाता है, फिर वह अपनी विशेषताओं के लिए मान प्रदान करना शुरू करता है।
उत्पादन
उपर्युक्त उदाहरण में, हम उन कमांड विशेषताओं या विधियों को देखते हैं, जिन्हें हम पैरेंट क्लास में रखते हैं ताकि सभी सबक्लासेस या चाइल्ड क्लास पैरेंट क्लास से उस संपत्ति को प्राप्त कर लें।
यदि एक उपवर्ग किसी अन्य उपवर्ग से विधियों या डेटा को इनहेरिट करने का प्रयास करता है, तो यह एक त्रुटि के माध्यम से होगा जैसा कि हम देखते हैं कि जब डॉग क्लास उस बिल्ली वर्ग से swatstring () विधियों को कॉल करने का प्रयास करता है, तो यह एक त्रुटि (जैसे हमारे मामले में एट्रीब्यूट्रम) को फेंकता है।
बहुरूपता ("कई आकार")
पॉलिमॉर्फिज्म पायथन में वर्ग परिभाषा की एक महत्वपूर्ण विशेषता है जिसका उपयोग तब किया जाता है जब आपके पास आमतौर पर कक्षाओं या उपवर्गों में नामित तरीके होते हैं। यह अलग-अलग समय पर विभिन्न प्रकार की संस्थाओं का उपयोग करने के लिए कार्य करता है। तो, यह लचीलापन और ढीली युग्मन प्रदान करता है ताकि कोड को बढ़ाया जा सके और समय के साथ आसानी से बनाए रखा जा सके।
यह इन पॉलीमॉर्फिक कक्षाओं में से किसी एक की वस्तुओं का उपयोग करने की अनुमति देता है, ताकि कक्षाओं में भेदों के बारे में जानकारी न हो।
बहुरूपता के माध्यम से बहुरूपता को ढोया जा सकता है, उपवर्गों को आधार वर्ग के तरीकों का उपयोग करने या उन्हें ओवरराइड करने के लिए।
हमारे पिछले वंशानुक्रम उदाहरण के साथ बहुरूपता की अवधारणा को समझने और दोनों उपवर्गों में show_affection नामक एक सामान्य विधि जोड़ें -
उदाहरण से हम देख सकते हैं, यह एक ऐसे डिजाइन को संदर्भित करता है जिसमें असमान प्रकार की वस्तु को एक ही तरीके से या समान रूप से दो या दो से अधिक वर्गों में समान नाम या सामान्य इंटरफ़ेस के साथ व्यवहार किया जा सकता है क्योंकि एक ही विधि (नीचे उदाहरण में show_affection) वस्तुओं के प्रकार के साथ कहा जाता है।
उत्पादन
इसलिए, सभी जानवर स्नेह (दिखावा) दिखाते हैं, लेकिन वे अलग तरह से करते हैं। इस प्रकार "show_affection" व्यवहार इस अर्थ में बहुरूपी है कि यह जानवर पर निर्भर करता है। तो, अमूर्त "पशु" की अवधारणा वास्तव में "show_affection" नहीं है, लेकिन विशिष्ट जानवरों (जैसे कुत्ते और बिल्लियों) "शो_आफक्शन" कार्रवाई का एक ठोस कार्यान्वयन है।
पायथन में ही ऐसी कक्षाएं हैं जो बहुरूपी हैं। उदाहरण, लेन () फ़ंक्शन का उपयोग कई ऑब्जेक्ट्स के साथ किया जा सकता है और सभी इनपुट पैरामीटर के आधार पर सही आउटपुट लौटाते हैं।
अधिभावी
पायथन में, जब एक उपवर्ग में एक ऐसी विधि होती है जो सुपरक्लास की एक विधि को ओवरराइड करती है, तो आप कॉल करके भी सुपरक्लास विधि कह सकते हैं
सुपर (उपवर्ग, स्व) .थेथोड ऑफ सेल्फमिथोड।
उदाहरण
class Thought(object):
def __init__(self):
pass
def message(self):
print("Thought, always come and go")
class Advice(Thought):
def __init__(self):
super(Advice, self).__init__()
def message(self):
print('Warning: Risk is always involved when you are dealing with market!')
कंस्ट्रक्टर का इनहेरिट करना
अगर हम अपने पिछले वंशानुक्रम के उदाहरण से देखें, तो __init__ पैरेंट क्लास में स्थित था, क्योंकि चाइल्ड क्लास डॉग या कैट में __init__ मेथड नहीं था। पायथन ने पशु वर्ग में __init__ को खोजने के लिए वंशानुक्रम विशेषता लुकअप का उपयोग किया। जब हमने चाइल्ड क्लास बनाई, तो सबसे पहले यह डॉग क्लास में __init__ मेथड को देखेगा, फिर इसे नहीं खोजा, फिर पेरेंट क्लास एनिमल में देखा और वहाँ पाया और वहाँ बुलाया। इसलिए जब हमारी कक्षा का डिजाइन जटिल हो गया, तो हम उदाहरण के तौर पर इसे मूल कक्षा के निर्माणकर्ता और फिर बाल वर्ग के निर्माणकर्ता के माध्यम से संसाधित करना शुरू कर सकते हैं।
उत्पादन
उपरोक्त उदाहरण में- सभी जानवरों का एक नाम और सभी कुत्ते एक विशेष नस्ल हैं। हमने सुपर के साथ पैरेंट क्लास कंस्ट्रक्टर को बुलाया। इसलिए कुत्ते का अपना __init__ है लेकिन पहली बात यह है कि हम सुपर कहते हैं। सुपर फ़ंक्शन में बनाया गया है और इसे एक वर्ग को उसके सुपर क्लास या उसके मूल वर्ग से संबंधित करने के लिए डिज़ाइन किया गया है।
इस मामले में हम कह रहे हैं कि कुत्ते के सुपर क्लास को प्राप्त करें और जो भी विधि हम यहां कहते हैं, वह कुत्ते का उदाहरण पास करें __init__। तो दूसरे शब्दों में हम कुत्ते की वस्तु के साथ माता-पिता को पशु __init__ कह रहे हैं। आप पूछ सकते हैं कि हम कुत्ते के उदाहरण के साथ पशु __init__ क्यों नहीं कहेंगे, हम ऐसा कर सकते हैं लेकिन अगर भविष्य में कुछ समय के लिए पशु वर्ग का नाम बदलना पड़े। क्या होगा अगर हम वर्ग पदानुक्रम को पुनर्व्यवस्थित करना चाहते हैं, इसलिए कुत्ते को दूसरे वर्ग से विरासत में मिला है। इस मामले में सुपर का उपयोग करना हमें चीजों को मॉड्यूलर और बदलने और बनाए रखने में आसान बनाता है।
तो इस उदाहरण में हम सामान्य __init__ कार्यक्षमता को अधिक विशिष्ट कार्यक्षमता के साथ संयोजित करने में सक्षम हैं। यह हमें सामान्य कार्यक्षमता को विशिष्ट कार्यक्षमता से अलग करने का अवसर देता है जो कोड दोहराव को समाप्त कर सकता है और कक्षा को एक दूसरे से संबंधित कर सकता है जो सिस्टम को समग्र डिजाइन को दर्शाता है।
निष्कर्ष
__init__ किसी अन्य विधि की तरह है; यह विरासत में मिल सकता है
यदि किसी वर्ग के पास __in____ कंस्ट्रक्टर नहीं है, तो पायथन अपने मूल वर्ग की जांच करेगा कि क्या वह एक खोज सकता है।
जैसे ही यह एक पाता है, पायथन इसे कॉल करता है और देखना बंद कर देता है
हम पैरेंट क्लास में कॉल के तरीकों के लिए सुपर () फ़ंक्शन का उपयोग कर सकते हैं।
हम माता-पिता के साथ-साथ अपनी कक्षा में भी इनिशियलाइज़ करना चाहते हैं।
एकाधिक वंशानुक्रम और लुकअप ट्री
जैसा कि इसके नाम से संकेत मिलता है, मल्टीपल इनहेरिटेंस पायथन है जब एक क्लास कई वर्गों से विरासत में मिलती है।
उदाहरण के लिए, एक बच्चा दोनों माता-पिता (माता और पिता) से व्यक्तित्व गुण प्राप्त करता है।
पायथन मल्टीपल इनहेरिटेंस सिंटेक्स
कई अभिभावकों की कक्षाओं से एक वर्ग की विरासत बनाने के लिए, हम इसे परिभाषित करते हुए कोष्ठक के अंदर इन वर्गों के नाम को व्युत्पन्न वर्ग में लिखते हैं। हम इन नामों को अल्पविराम से अलग करते हैं।
नीचे इसका एक उदाहरण है -
>>> class Mother:
pass
>>> class Father:
pass
>>> class Child(Mother, Father):
pass
>>> issubclass(Child, Mother) and issubclass(Child, Father)
True
एकाधिक वंशानुक्रम दो या दो से अधिक वर्ग से विरासत की क्षमता को संदर्भित करता है। माता-पिता से विरासत में मिली संतान और माता-पिता के दादा-दादी से विरासत में मिली जटिलताएं पैदा होती हैं। अजगर एक विरासत वाले पेड़ पर चढ़ता है जो उन विशेषताओं की तलाश करता है जिन्हें किसी वस्तु से पढ़ने का अनुरोध किया जा रहा है। यह उदाहरण में, वर्ग के बाद मूल वर्ग और अंत में दादा दादी वर्ग से जाँच करेगा। अब सवाल यह उठता है कि कक्षाओं को किस क्रम में खोजा जाएगा - सांस-पहले या गहराई-पहले। डिफ़ॉल्ट रूप से, पायथन गहराई-पहले के साथ जाता है।
यही कारण है कि नीचे दिए गए चित्र में पायथन डॉथिस () विधि को कक्षा ए में खोजता है, इसलिए नीचे दिए गए उदाहरण में विधि संकल्प क्रम होगा
Mro- D→B→A→C
नीचे देखें कई उत्तराधिकार आरेख -
आइए एक उदाहरण के माध्यम से समझते हैं कि पायथन की "मेरो" सुविधा को समझने के लिए।
उत्पादन
उदाहरण 3
चलो "हीरे के आकार" का एक और उदाहरण लेते हैं।
ऊपर आरेख को अस्पष्ट माना जाएगा। हमारे पिछले उदाहरण को समझने के लिए "विधि संकल्प क्रम" .ie mro होगा D → B → A → C → A लेकिन यह नहीं है। C से दूसरा A प्राप्त करने पर, Python पिछले A को अनदेखा कर देगा इसलिए mro इस मामले में D → B → C → A होगा।
आइए उपरोक्त आरेख के आधार पर एक उदाहरण बनाएं -
उत्पादन
उपरोक्त आउटपुट को समझने के लिए सरल नियम है- यदि विधि रिज़ॉल्यूशन ऑर्डर में एक ही वर्ग दिखाई देता है, तो इस क्लास के पहले के डिस्प्ले को विधि रिज़ॉल्यूशन ऑर्डर से हटा दिया जाएगा।
निष्कर्ष में -
कोई भी वर्ग कई वर्गों से विरासत में मिल सकता है
विरासत वर्ग को खोजते समय पायथन आमतौर पर "गहराई-पहले" क्रम का उपयोग करता है।
लेकिन जब एक ही वर्ग से दो कक्षाएं विरासत में मिलती हैं, तो पायथन एमआरओ से उस वर्ग की पहली उपस्थिति को समाप्त कर देता है।
डेकोरेटर्स, स्टेटिक और क्लास मेथड्स
कार्य (या विधियाँ) डीफ़ स्टेटमेंट द्वारा बनाए गए हैं।
यद्यपि विधियाँ ठीक उसी तरह से कार्य करती हैं जैसे कि एक बिंदु को छोड़कर जहां विधि का पहला तर्क उदाहरण वस्तु है।
हम उनके व्यवहार के आधार पर तरीकों को वर्गीकृत कर सकते हैं, जैसे कि
Simple method- एक वर्ग के बाहर परिभाषित। यह फ़ंक्शन इंस्टेंस फ़ीड को तर्क वितर्क द्वारा एक्सेस कर सकता है:
def outside_func(():
Instance method -
def func(self,)
Class method - अगर हमें क्लास की विशेषताओं का उपयोग करने की आवश्यकता है
@classmethod
def cfunc(cls,)
Static method - कक्षा के बारे में कोई जानकारी नहीं है
@staticmethod
def sfoo()
अब तक हमने उदाहरण विधि देखी है, अब समय आ गया है कि अन्य दो विधियों में कुछ जानकारी प्राप्त की जाए,
कक्षा विधि
@Classmethod डेकोरेटर, एक बिल्टिन फंक्शन डेकोरेटर है, जो उस कक्षा में उत्तीर्ण हो जाता है जिसे यह कहा जाता था या उदाहरण के वर्ग को प्रथम तर्क के रूप में कहा जाता था। उस मूल्यांकन का परिणाम आपके फ़ंक्शन की परिभाषा को छाया देता है।
वाक्य - विन्यास
class C(object):
@classmethod
def fun(cls, arg1, arg2, ...):
....
fun: function that needs to be converted into a class method
returns: a class method for function
उनके पास इस cls तर्क की पहुंच है, यह ऑब्जेक्ट इंस्टेंस स्थिति को संशोधित नहीं कर सकता है। इसके लिए स्व तक पहुंच की आवश्यकता होगी।
यह वर्ग के लिए बाध्य है न कि कक्षा की वस्तु के लिए।
कक्षा विधियां अभी भी वर्ग स्थिति को संशोधित कर सकती हैं जो कक्षा के सभी उदाहरणों पर लागू होती हैं।
स्थैतिक विधि
एक स्थैतिक विधि न तो स्वयं को और न ही एक cls (वर्ग) पैरामीटर को लेती है, लेकिन यह अन्य मापदंडों की एक मनमानी संख्या को स्वीकार करने के लिए स्वतंत्र है।
syntax
class C(object):
@staticmethod
def fun(arg1, arg2, ...):
...
returns: a static method for function funself.
- एक स्थैतिक विधि न तो ऑब्जेक्ट स्टेट को संशोधित कर सकती है और न ही क्लास स्टेट को।
- वे प्रतिबंधित हैं कि वे किस डेटा तक पहुंच सकते हैं।
कब क्या उपयोग करना है
हम आम तौर पर कारखाने के तरीकों को बनाने के लिए वर्ग विधि का उपयोग करते हैं। अलग-अलग उपयोग के मामलों के लिए कारखाने के तरीके क्लास ऑब्जेक्ट (एक कंस्ट्रक्टर के समान) वापस करते हैं।
हम आम तौर पर उपयोगिता कार्यों को बनाने के लिए स्थैतिक तरीकों का उपयोग करते हैं।