एफ # - इंटरफेस

इंटरफेस एक वर्ग के कार्यान्वयन विवरण को लिखने का एक सार तरीका प्रदान करते हैं। यह एक टेम्पलेट है जो उन तरीकों की घोषणा करता है जिन्हें कक्षा को सार्वजनिक रूप से लागू करना और उजागर करना चाहिए।

वाक्य - विन्यास

एक इंटरफ़ेस संबंधित सदस्यों के सेट को निर्दिष्ट करता है जो अन्य वर्ग लागू करते हैं। इसके निम्नलिखित सिंटैक्स हैं -

// Interface declaration:
[ attributes ]
type interface-name =
   [ interface ]
      [ inherit base-interface-name ...]
      abstract member1 : [ argument-types1 -> ] return-type1
      abstract member2 : [ argument-types2 -> ] return-type2
      ...
   [ end ]
	
// Implementing, inside a class type definition:
interface interface-name with
   member self-identifier.member1 argument-list = method-body1
   member self-identifier.member2 argument-list = method-body2
// Implementing, by using an object expression:
[ attributes ]
let class-name (argument-list) =
   { new interface-name with
      member self-identifier.member1 argument-list = method-body1
      member self-identifier.member2 argument-list = method-body2
      [ base-interface-definitions ]
   }
member-list

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

  • एक इंटरफ़ेस घोषणा में सदस्यों को लागू नहीं किया जाता है।

  • सदस्य अमूर्त हैं, जिनके द्वारा घोषित किया गया है abstractकीवर्ड। हालाँकि आप का उपयोग करके एक डिफ़ॉल्ट कार्यान्वयन प्रदान कर सकते हैंdefault कीवर्ड।

  • आप ऑब्जेक्ट भावों का उपयोग करके या वर्ग प्रकारों का उपयोग करके इंटरफेस को लागू कर सकते हैं।

  • कक्षा या ऑब्जेक्ट कार्यान्वयन में, आपको इंटरफ़ेस के सार तरीकों के लिए विधि निकाय प्रदान करने की आवश्यकता है।

  • कीवर्ड interface तथा end, जो परिभाषा के प्रारंभ और अंत को चिह्नित करते हैं, वैकल्पिक हैं।

उदाहरण के लिए,

type IPerson =
   abstract Name : string
   abstract Enter : unit -> unit
   abstract Leave : unit -> unit

कॉलिंग इंटरफ़ेस तरीके

इंटरफ़ेस विधियों को इंटरफ़ेस के माध्यम से बुलाया जाता है, न कि कक्षा के उदाहरण के माध्यम से या इंटरफ़ेस लागू करने के प्रकार के माध्यम से। एक इंटरफ़ेस विधि को कॉल करने के लिए, आप का उपयोग करके इंटरफ़ेस प्रकार के लिए डाली:> ऑपरेटर (upcast ऑपरेटर)।

उदाहरण के लिए,

(s :> IPerson).Enter()
(s :> IPerson).Leave()

निम्नलिखित उदाहरण अवधारणा को दर्शाता है -

उदाहरण

type IPerson =
   abstract Name : string
   abstract Enter : unit -> unit
   abstract Leave : unit -> unit

type Student(name : string, id : int) =
   member this.ID = id
   interface IPerson with
      member this.Name = name
      member this.Enter() = printfn "Student entering premises!"
      member this.Leave() = printfn "Student leaving premises!"

type StuffMember(name : string, id : int, salary : float) =
   let mutable _salary = salary

   member this.Salary
      with get() = _salary
      and set(value) = _salary <- value

   interface IPerson with
      member this.Name = name
      member this.Enter() = printfn "Stuff member entering premises!"
      member this.Leave() = printfn "Stuff member leaving premises!"

let s = new Student("Zara", 1234)
let st = new StuffMember("Rohit", 34, 50000.0)

(s :> IPerson).Enter()
(s :> IPerson).Leave()
(st :> IPerson).Enter()
(st :> IPerson).Leave()

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

Student entering premises!
Student leaving premises!
Stuff member entering premises!
Stuff member leaving premises!

इंटरफ़ेस वंशानुक्रम

इंटरफेस एक या अधिक आधार इंटरफेस से विरासत में मिल सकते हैं।

निम्नलिखित उदाहरण अवधारणा को दर्शाता है -

type Interface1 =
   abstract member doubleIt: int -> int

type Interface2 =
   abstract member tripleIt: int -> int

type Interface3 =
   inherit Interface1
   inherit Interface2
   abstract member printIt: int -> string

type multiplierClass() =
   interface Interface3 with
      member this.doubleIt(a) = 2 * a
      member this.tripleIt(a) = 3 * a
      member this.printIt(a) = a.ToString()

let ml = multiplierClass()
printfn "%d" ((ml:>Interface3).doubleIt(5))
printfn "%d" ((ml:>Interface3).tripleIt(5))
printfn "%s" ((ml:>Interface3).printIt(5))

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

10
15
5