एफ # - वंशानुक्रम

ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग में सबसे महत्वपूर्ण अवधारणाओं में से एक विरासत की है। वंशानुक्रम हमें एक वर्ग को दूसरी कक्षा के संदर्भ में परिभाषित करने की अनुमति देता है, जिससे एप्लिकेशन बनाना और उसे बनाए रखना आसान हो जाता है। यह कोड कार्यक्षमता और तेजी से कार्यान्वयन समय का पुन: उपयोग करने का अवसर भी प्रदान करता है।

कक्षा बनाते समय, पूरी तरह से नए डेटा सदस्यों और सदस्य कार्यों को लिखने के बजाय, प्रोग्रामर यह नामित कर सकता है कि नए वर्ग को किसी मौजूदा वर्ग के सदस्यों को विरासत में प्राप्त करना चाहिए। इस मौजूदा वर्ग को बेस क्लास कहा जाता है, और नए वर्ग को व्युत्पन्न वर्ग कहा जाता है।

विरासत का विचार आईएस-ए संबंध को लागू करता है। उदाहरण के लिए, स्तनपायी IS एक जानवर है, कुत्ता IS-A स्तनपायी है इसलिए कुत्ता IS-A पशु भी है।

बेस क्लास और सब क्लास

एक उपवर्ग एक बेस क्लास से लिया गया है, जो पहले से ही परिभाषित है। एक उपवर्ग बेस क्लास के सदस्यों को विरासत में मिला है, साथ ही इसके अपने सदस्य भी हैं।

एक उपवर्ग का उपयोग करके परिभाषित किया गया है inherit नीचे दिखाया गया कीवर्ड -

type MyDerived(...) =
   inherit MyBase(...)

F # में, एक कक्षा में अधिकतम एक प्रत्यक्ष आधार वर्ग हो सकता है। यदि आप आधार वर्ग का उपयोग करके निर्दिष्ट नहीं करते हैंinherit कीवर्ड, वर्ग का तात्पर्य ऑब्जेक्ट से विरासत में मिला है।

कृपया ध्यान दें -

  • आधार वर्ग के तरीके और सदस्य व्युत्पन्न वर्ग के उपयोगकर्ताओं के लिए उपलब्ध हैं, जैसे कि व्युत्पन्न वर्ग के प्रत्यक्ष सदस्य।

  • बता दें कि बाइंडिंग और कंस्ट्रक्टर पैरामीटर एक वर्ग के लिए निजी हैं और इसलिए, व्युत्पन्न वर्गों से प्रवेश नहीं किया जा सकता है।

  • कीवर्ड baseबेस क्लास उदाहरण को संदर्भित करता है। इसका उपयोग स्व-पहचानकर्ता की तरह किया जाता है।

उदाहरण

type Person(name) =
   member x.Name = name
   member x.Greet() = printfn "Hi, I'm %s" x.Name

type Student(name, studentID : int) =
   inherit Person(name)
   let mutable _GPA = 0.0
   member x.StudentID = studentID
   member x.GPA
      with get() = _GPA
      and set value = _GPA <- value

type Teacher(name, expertise : string) =
   inherit Person(name)

   let mutable _salary = 0.0
   member x.Salary
      with get() = _salary
      and set value = _salary <- value
   member x.Expertise = expertise

//using the subclasses
let p = new Person("Mohan")
let st = new Student("Zara", 1234)
let tr = new Teacher("Mariam", "Java")

p.Greet()
st.Greet()
tr.Greet()

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Hi, I'm Mohan
Hi, I'm Zara
Hi, I'm Mariam

ओवरराइडिंग के तरीके

आप बेस क्लास विधि के एक डिफ़ॉल्ट व्यवहार को ओवरराइड कर सकते हैं और इसे उपवर्ग या व्युत्पन्न वर्ग में अलग-अलग लागू कर सकते हैं।

F # में विधियां डिफ़ॉल्ट रूप से अधिक महत्वपूर्ण नहीं हैं।

एक व्युत्पन्न वर्ग में तरीकों को ओवरराइड करने के लिए, आपको अपनी विधि को उपयोग करने योग्य घोषित करना होगा abstract तथा default कीवर्ड निम्नानुसार हैं -

type Person(name) =
   member x.Name = name
   abstract Greet : unit -> unit
   default x.Greet() = printfn "Hi, I'm %s" x.Name

अब, व्युत्पन्न वर्गों में व्यक्ति वर्ग की ग्रीट पद्धति को ओवरराइड किया जा सकता है। निम्न उदाहरण यह प्रदर्शित करता है -

उदाहरण

type Person(name) =
   member x.Name = name
   abstract Greet : unit -> unit
   default x.Greet() = printfn "Hi, I'm %s" x.Name

type Student(name, studentID : int) =
   inherit Person(name)

   let mutable _GPA = 0.0

   member x.StudentID = studentID
   member x.GPA
      with get() = _GPA
      and set value = _GPA <- value
   override x.Greet() = printfn "Student %s" x.Name

type Teacher(name, expertise : string) =
   inherit Person(name)
   let mutable _salary = 0.0
   member x.Salary
      with get() = _salary
      and set value = _salary <- value

   member x.Expertise = expertise
   override x.Greet() = printfn "Teacher %s." x.Name

//using the subclasses
let p = new Person("Mohan")
let st = new Student("Zara", 1234)
let tr = new Teacher("Mariam", "Java")

//default Greet
p.Greet()

//Overriden Greet
st.Greet()
tr.Greet()

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Hi, I'm Mohan
Student Zara
Teacher Mariam.

सार वर्ग

कई बार आपको किसी वस्तु का अपूर्ण कार्यान्वयन प्रदान करने की आवश्यकता होती है, जिसे वास्तविकता में लागू नहीं किया जाना चाहिए। बाद में, कुछ अन्य प्रोग्रामर को अमूर्त वर्ग के उपवर्गों को पूर्ण कार्यान्वयन के लिए बनाना चाहिए।

उदाहरण के लिए, स्कूल प्रबंधन प्रणाली में व्यक्ति वर्ग की आवश्यकता नहीं होगी। हालांकि, छात्र या शिक्षक वर्ग की जरूरत होगी। ऐसे मामलों में, आप व्यक्ति वर्ग को सार वर्ग घोषित कर सकते हैं।

AbstractClass विशेषता कंपाइलर को बताती है कि कक्षा में कुछ सार सदस्य हैं।

आप एक अमूर्त वर्ग का उदाहरण नहीं बना सकते क्योंकि वर्ग पूरी तरह से लागू नहीं हुआ है।

निम्न उदाहरण यह प्रदर्शित करता है -

उदाहरण

[<AbstractClass>]
type Person(name) =
   member x.Name = name
   abstract Greet : unit -> unit

type Student(name, studentID : int) =
   inherit Person(name)
   let mutable _GPA = 0.0
   member x.StudentID = studentID
   member x.GPA
      with get() = _GPA
      and set value = _GPA <- value
   override x.Greet() = printfn "Student %s" x.Name

type Teacher(name, expertise : string) =
   inherit Person(name)
   let mutable _salary = 0.0
   member x.Salary
      with get() = _salary
      and set value = _salary <- value
   member x.Expertise = expertise
   override x.Greet() = printfn "Teacher %s." x.Name

let st = new Student("Zara", 1234)
let tr = new Teacher("Mariam", "Java")

//Overriden Greet
st.Greet()
tr.Greet()

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Student Zara
Teacher Mariam.