एफ # - कक्षाएं
वर्ग वे प्रकार हैं जो उन वस्तुओं का प्रतिनिधित्व करते हैं जिनमें गुण, विधियाँ और घटनाएँ हो सकती हैं। 'उनका उपयोग अनुप्रयोगों में क्रियाओं, प्रक्रियाओं और किसी भी वैचारिक संस्थाओं के मॉडल के लिए किया जाता है।'
वाक्य - विन्यास
एक वर्ग प्रकार को परिभाषित करने के लिए सिंटैक्स निम्नानुसार है -
// Class definition:
type [access-modifier] type-name [type-params] [access-modifier] ( parameter-list ) [ as identifier ] =
[ class ]
[ inherit base-type-name(base-constructor-args) ]
[ let-bindings ]
[ do-bindings ]
member-list
...
[ end ]
// Mutually recursive class definitions:
type [access-modifier] type-name1 ...
and [access-modifier] type-name2 ...
...
कहाँ पे,
type-nameकोई भी मान्य पहचानकर्ता है। इसके लिए डिफ़ॉल्ट एक्सेस मॉडिफायर हैpublic।
type-params वैकल्पिक सामान्य प्रकार के मापदंडों का वर्णन करता है।
parameter-listनिर्माता मापदंडों का वर्णन करता है। प्राथमिक निर्माता के लिए डिफ़ॉल्ट पहुँच संशोधक हैpublic।
identifier वैकल्पिक के साथ प्रयोग किया जाता है as कीवर्ड उदाहरण चर के लिए एक नाम देता है, या self-identifier, जिसका उपयोग टाइप परिभाषा में टाइप के उदाहरण को संदर्भित करने के लिए किया जा सकता है।
inherit कीवर्ड आपको एक वर्ग के लिए आधार वर्ग निर्दिष्ट करने की अनुमति देता है।
let बाइंडिंग आपको फ़ील्ड को स्थानीय घोषित करने या फ़ंक्शन करने की अनुमति देता है।
do-bindings अनुभाग में ऑब्जेक्ट निर्माण पर निष्पादित होने वाला कोड शामिल है।
member-list अतिरिक्त कंस्ट्रक्टर, उदाहरण और स्थिर विधि घोषणाओं, इंटरफ़ेस घोषणाओं, अमूर्त बाइंडिंग, और संपत्ति और घटना घोषणाओं के होते हैं।
कीवर्ड class तथा end परिभाषा की शुरुआत और अंत वैकल्पिक हैं।
एक वर्ग का निर्माता
कंस्ट्रक्टर कोड है जो वर्ग प्रकार का एक उदाहरण बनाता है।
F # में, कंस्ट्रक्टर अन्य .Net भाषाओं की तुलना में बहुत कम काम करते हैं। कक्षा की परिभाषा में, प्राथमिक निर्माता के तर्क को पैरामीटर-सूची के रूप में वर्णित किया गया है।
कंस्ट्रक्टर के शरीर में होते हैं let तथा do बाइंडिंग।
आप सदस्य जोड़ने के लिए नए कीवर्ड का उपयोग करके अतिरिक्त कंस्ट्रक्टर जोड़ सकते हैं -
new (argument-list) = constructor-body
निम्नलिखित उदाहरण अवधारणा को दर्शाता है -
उदाहरण
निम्न प्रोग्राम एक निर्माता के साथ एक लाइन क्लास बनाता है जो लाइन की लंबाई की गणना करता है जबकि क्लास का एक ऑब्जेक्ट बनाया जाता है -
type Line = class
val X1 : float
val Y1 : float
val X2 : float
val Y2 : float
new (x1, y1, x2, y2) as this =
{ X1 = x1; Y1 = y1; X2 = x2; Y2 = y2;}
then
printfn " Creating Line: {(%g, %g), (%g, %g)}\nLength: %g"
this.X1 this.Y1 this.X2 this.Y2 this.Length
member x.Length =
let sqr x = x * x
sqrt(sqr(x.X1 - x.X2) + sqr(x.Y1 - x.Y2) )
end
let aLine = new Line(1.0, 1.0, 4.0, 5.0)
जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -
Creating Line: {(1, 1), (4, 5)}
Length: 5
बाँधने दो
कक्षा की परिभाषा में बाँधने से आप एफ # कक्षाओं के लिए निजी क्षेत्रों और निजी कार्यों को परिभाषित कर सकते हैं।
type Greetings(name) as gr =
let data = name
do
gr.PrintMessage()
member this.PrintMessage() =
printf "Hello %s\n" data
let gtr = new Greetings("Zara")
जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -
Hello Zara
कृपया ग्रीटिंग्स वर्ग के लिए स्व-पहचानकर्ता जीआर के उपयोग पर ध्यान दें ।