एफ # - इंटरफेस
इंटरफेस एक वर्ग के कार्यान्वयन विवरण को लिखने का एक सार तरीका प्रदान करते हैं। यह एक टेम्पलेट है जो उन तरीकों की घोषणा करता है जिन्हें कक्षा को सार्वजनिक रूप से लागू करना और उजागर करना चाहिए।
वाक्य - विन्यास
एक इंटरफ़ेस संबंधित सदस्यों के सेट को निर्दिष्ट करता है जो अन्य वर्ग लागू करते हैं। इसके निम्नलिखित सिंटैक्स हैं -
// 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