एफ # - त्वरित गाइड

एफ # एक कार्यात्मक प्रोग्रामिंग भाषा है। एफ # कंस्ट्रक्शंस को समझने के लिए, आपको नामांकित प्रोग्रामिंग प्रतिमान के बारे में कुछ पंक्तियों को पढ़ने की आवश्यकता हैFunctional Programming

कार्यात्मक प्रोग्रामिंग कंप्यूटर कार्यक्रमों को गणितीय कार्यों के रूप में मानते हैं। फ़ंक्शनल प्रोग्रामिंग में, वेरिएबल्स और स्टेट्स के बजाय, कॉन्स्टेंट और फ़ंक्शंस पर ध्यान दिया जाएगा। क्योंकि फ़ंक्शंस और कॉन्स्टेंट ऐसी चीजें हैं जो बदलती नहीं हैं।

फ़ंक्शनल प्रोग्रामिंग में, आप मॉड्यूलर प्रोग्राम लिखेंगे, यानी, प्रोग्राम में ऐसे फ़ंक्शंस होंगे जो इनपुट के रूप में अन्य फ़ंक्शंस लेंगे।

कार्यात्मक प्रोग्रामिंग भाषा में लिखे गए कार्यक्रम संक्षिप्त होते हैं।

F # के बारे में

F # के बारे में मूल जानकारी निम्नलिखित हैं -

  • इसे 2005 में Microsoft रिसर्च में विकसित किया गया था।
  • यह Microsoft की .Net भाषा के परिवार का एक हिस्सा है।
  • यह एक कार्यात्मक प्रोग्रामिंग भाषा है।
  • यह कार्यात्मक प्रोग्रामिंग भाषा OCaml पर आधारित है।

F # की विशेषताएं

  • यह OCaml का नेट कार्यान्वयन है।

  • यह .Net CLI (सामान्य भाषा इंटरफ़ेस) बाइट कोड या MSIL (Microsoft मध्यवर्ती भाषा) को संकलित करता है जो CLR (सामान्य भाषा रनटाइम) पर चलता है।

  • यह प्रकार का अनुमान प्रदान करता है।

  • यह समृद्ध पैटर्न मिलान निर्माण प्रदान करता है।

  • इसमें इंटरैक्टिव स्क्रिप्टिंग और डिबगिंग क्षमताएं हैं।

  • यह उच्च क्रम के कार्यों को लिखने की अनुमति देता है।

  • यह अच्छी तरह से विकसित वस्तु मॉडल प्रदान करता है।

एफ # का उपयोग

F # का उपयोग आमतौर पर निम्नलिखित क्षेत्रों में किया जाता है -

  • वैज्ञानिक मॉडल बनाना
  • गणित की समस्या हल करना
  • कृत्रिम बुद्धिमत्ता अनुसंधान कार्य
  • वित्तीय मॉडलिंग
  • ग्राफ़िक डिज़ाइन
  • सीपीयू डिजाइन
  • संकलक प्रोग्रामिंग
  • Telecommunications

इसका उपयोग CRUD ऐप, वेब पेज, GUI गेम्स और अन्य सामान्य प्रयोजन कार्यक्रमों में भी किया जाता है।

इस अध्याय में F # प्रोग्रामिंग के लिए आवश्यक उपकरणों पर चर्चा की गई है।

F # के लिए एकीकृत विकास पर्यावरण (IDE)

Microsoft F # प्रोग्रामिंग के लिए Visual Studio 2013 प्रदान करता है।

मुफ्त विजुअल स्टूडियो 2013 सामुदायिक संस्करण माइक्रोसॉफ्ट की आधिकारिक वेबसाइट से उपलब्ध है। विजुअल स्टूडियो 2013 समुदाय और इसके बाद के संस्करण दृश्य एफ # उपकरण के साथ आता है। Asp.net ट्यूटोरियल में उपलब्ध इंस्टॉलेशन विवरण । विजुअल F # टूल्स में कमांड-लाइन कंपाइलर (fsc.exe) और F # इंटरएक्टिव (fsi.exe) शामिल हैं।

इन उपकरणों का उपयोग करके, आप साधारण कमांड लाइन अनुप्रयोगों से अधिक जटिल अनुप्रयोगों तक सभी प्रकार के एफ # प्रोग्राम लिख सकते हैं। आप मूल पाठ संपादक की तरह एफ # स्रोत कोड फ़ाइलों को भी लिख सकते हैं, जैसे नोटपैड, और कमांड-लाइन कंपाइलर का उपयोग करके कोड को असेंबली में संकलित करते हैं।

आप इसे Microsoft Visual Studio से डाउनलोड कर सकते हैं। यह स्वचालित रूप से आपकी मशीन में स्थापित हो जाता है।

लिंक पर एफ # प्रोग्राम लिखना

उपकरण को डेबियन पैकेज के रूप में प्राप्त करने या उन्हें सीधे स्रोत से सीधे संकलित करने के लिए कृपया नवीनतम निर्देशों के लिए F # आधिकारिक वेबसाइट देखें - https://fsharp.org/use/linux/.

एफ # एक कार्यात्मक प्रोग्रामिंग भाषा है।

F # में, फ़ंक्शन डेटा प्रकारों की तरह काम करते हैं। आप किसी अन्य चर की तरह ही फ़ंक्शन की घोषणा और उपयोग कर सकते हैं।

सामान्य तौर पर, एफ # एप्लिकेशन में कोई विशिष्ट प्रवेश बिंदु नहीं होता है। कंपाइलर फ़ाइल में ऊपर से नीचे तक सभी शीर्ष-स्तरीय कथनों को निष्पादित करता है।

हालाँकि, प्रक्रियात्मक प्रोग्रामिंग शैली का पालन करने के लिए, कई अनुप्रयोग एकल शीर्ष स्तर का स्टेटमेंट रखते हैं जो मुख्य लूप को कॉल करता है।

निम्नलिखित कोड एक सरल एफ # कार्यक्रम दिखाता है -

open System
(* This is a multi-line comment *)
// This is a single-line comment

let sign num =
   if num > 0 then "positive"
   elif num < 0 then "negative"
   else "zero"

let main() =
   Console.WriteLine("sign 5: {0}", (sign 5))

main()

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

sign 5: positive

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

  • F # कोड फ़ाइल कई की संख्या से शुरू हो सकती है open नाम स्थान को आयात करने के लिए उपयोग किए जाने वाले कथन।

  • फ़ाइलों के शरीर में अन्य कार्य शामिल हैं जो एप्लिकेशन के व्यावसायिक तर्क को लागू करते हैं।

  • मुख्य लूप में शीर्ष निष्पादन योग्य कथन होते हैं।

आपने एफ # प्रोग्राम की मूल संरचना देखी है, इसलिए एफ # प्रोग्रामिंग भाषा के अन्य बुनियादी बिल्डिंग ब्लॉकों को समझना आसान होगा।

एफ # में टोकन

एक एफ # कार्यक्रम में विभिन्न टोकन शामिल हैं। एक टोकन एक कीवर्ड, एक पहचानकर्ता, एक स्थिर, एक स्ट्रिंग शाब्दिक या एक प्रतीक हो सकता है। हम F # टोकन को दो प्रकारों में वर्गीकृत कर सकते हैं -

  • Keywords
  • प्रतीक और संचालक

एफ # कीवर्ड

निम्न तालिका कीवर्ड और कीवर्ड का संक्षिप्त विवरण दिखाती है। हम बाद के अध्यायों में इन खोजशब्दों के उपयोग पर चर्चा करेंगे।

कीवर्ड विवरण
abstract एक ऐसी विधि को इंगित करता है जिसमें या तो उस प्रकार का कोई कार्यान्वयन नहीं है जिसमें वह घोषित किया गया है या जो आभासी है और जिसका डिफ़ॉल्ट कार्यान्वयन है।
and संपत्ति की घोषणाओं में, और सामान्य मापदंडों पर कई बाधाओं के साथ पारस्परिक रूप से पुनरावर्ती बाइंडिंग में उपयोग किया जाता है।
as वर्तमान वर्ग वस्तु को एक वस्तु का नाम देने के लिए उपयोग किया जाता है। एक पैटर्न मैच के भीतर एक पूरे पैटर्न को एक नाम देने के लिए भी उपयोग किया जाता है।
assert डिबगिंग के दौरान कोड को सत्यापित करने के लिए उपयोग किया जाता है।
base बेस क्लास ऑब्जेक्ट के नाम के रूप में उपयोग किया जाता है।
begin वर्बोस सिंटैक्स में, एक कोड ब्लॉक की शुरुआत को इंगित करता है।
class वर्बोस सिंटैक्स में, वर्ग परिभाषा की शुरुआत इंगित करता है।
default एक अमूर्त विधि के कार्यान्वयन का संकेत देता है; एक आभासी विधि बनाने के लिए एक अमूर्त विधि घोषणा के साथ प्रयोग किया जाता है।
delegate एक प्रतिनिधि घोषित करने के लिए उपयोग किया जाता है।
do लूपिंग निर्माण में उपयोग किया जाता है या अनिवार्य कोड निष्पादित करने के लिए।
done वर्बोस सिंटैक्स में, लूपिंग अभिव्यक्ति में कोड के एक ब्लॉक के अंत को इंगित करता है।
downcast एक प्रकार में परिवर्तित करने के लिए उपयोग किया जाता है जो वंशानुक्रम श्रृंखला में कम होता है।
downto में for अभिव्यक्ति, रिवर्स में गिनती करते समय उपयोग किया जाता है।
elif सशर्त शाखाओं में उपयोग किया जाता है। अन्य का संक्षिप्त रूप यदि।
else सशर्त शाखाओं में उपयोग किया जाता है।
end

प्रकार की परिभाषाओं और प्रकार के एक्सटेंशनों में, सदस्य परिभाषाओं के एक खंड के अंत को इंगित करता है।

वर्बोस सिंटैक्स में, एक कोड ब्लॉक के अंत को निर्दिष्ट करने के लिए उपयोग किया जाता है जो शुरुआती कीवर्ड के साथ शुरू होता है।

exception एक अपवाद प्रकार की घोषणा करने के लिए उपयोग किया जाता है।
extern इंगित करता है कि एक घोषित प्रोग्राम तत्व किसी अन्य बाइनरी या असेंबली में परिभाषित किया गया है।
false एक बूलियन शाब्दिक के रूप में उपयोग किया जाता है।
finally एक कोड का एक ब्लॉक शुरू करने की कोशिश के साथ प्रयोग किया जाता है जो अपवाद के बिना निष्पादित होता है।
for लूपिंग निर्माण में उपयोग किया जाता है।
fun लैंबडा एक्सप्रेशंस में उपयोग किया जाता है, जिसे गुमनाम कार्यों के रूप में भी जाना जाता है।
function मजेदार कीवर्ड के लिए एक छोटे विकल्प के रूप में उपयोग किया जाता है और एक लैम्ब्डा अभिव्यक्ति में एक मैच अभिव्यक्ति है जिसमें एकल तर्क पर पैटर्न मिलान होता है।
global शीर्ष-स्तरीय .NET नाम स्थान का संदर्भ देने के लिए उपयोग किया जाता है।
if सशर्त शाखाओं के निर्माण में उपयोग किया जाता है।
in अनुक्रम अभिव्यक्तियों के लिए और, क्रिया सिंटैक्स में, बाइंडिंग से अभिव्यक्ति को अलग करने के लिए उपयोग किया जाता है।
inherit बेस क्लास या बेस इंटरफेस निर्दिष्ट करने के लिए उपयोग किया जाता है।
inline एक फ़ंक्शन को इंगित करने के लिए उपयोग किया जाता है जिसे सीधे कॉलर कोड में एकीकृत किया जाना चाहिए।
interface इंटरफेस घोषित करने और लागू करने के लिए उपयोग किया जाता है।
internal यह निर्दिष्ट करने के लिए उपयोग किया जाता है कि कोई सदस्य किसी असेंबली के अंदर दिखाई देता है, लेकिन उसके बाहर नहीं।
lazy एक संगणना निर्दिष्ट करने के लिए उपयोग किया जाता है जो केवल तब किया जाता है जब किसी परिणाम की आवश्यकता होती है।
let एक मूल्य या कार्य के लिए सहयोगी, या बाइंड का नाम।
let! एक अतुल्यकालिक गणना के परिणाम के लिए एक नाम को बांधने के लिए अतुल्यकालिक वर्कफ़्लोज़ में उपयोग किया जाता है, या, अन्य संगणना अभिव्यक्तियों में, एक नाम को परिणाम के लिए बाँधने के लिए उपयोग किया जाता है, जो गणना प्रकार का होता है।
match एक मूल्य को एक पैटर्न से तुलना करके शाखा में उपयोग किया जाता है।
member एक वस्तु प्रकार में एक संपत्ति या विधि घोषित करने के लिए उपयोग किया जाता है।
module किसी नाम को संबंधित प्रकारों, मूल्यों और कार्यों के समूह के साथ जोड़ने के लिए, इसे अन्य कोड से तार्किक रूप से अलग करने के लिए उपयोग किया जाता है।
mutable एक वैरिएबल घोषित करने के लिए उपयोग किया जाता है, अर्थात, एक मूल्य जिसे बदला जा सकता है।
namespace किसी नाम को संबंधित प्रकार और मॉड्यूल के समूह के साथ जोड़ने के लिए, तार्किक रूप से इसे अन्य कोड से अलग करने के लिए उपयोग किया जाता है।
new

निर्माण करने वाले को घोषित करने, परिभाषित करने या आह्वान करने के लिए उपयोग किया जाता है जो एक वस्तु का निर्माण या निर्माण कर सकता है।

यह भी इंगित करने के लिए सामान्य पैरामीटर में उपयोग किया जाता है कि एक प्रकार का एक निश्चित निर्माता होना चाहिए।

not वास्तव में कोई कीवर्ड नहीं है। हालांकि, संयोजन में संरचना का उपयोग सामान्य पैरामीटर बाधा के रूप में नहीं किया जाता है।
null

किसी वस्तु की अनुपस्थिति का संकेत देता है।

जेनेरिक पैरामीटर बाधाओं में भी उपयोग किया जाता है।

of मूल्यों की श्रेणियों के प्रकार और प्रतिनिधि और अपवाद घोषणाओं में संकेत देने के लिए भेदभाव वाली यूनियनों में उपयोग किया जाता है।
open योग्यता के बिना किसी नाम स्थान या मॉड्यूल की सामग्री उपलब्ध कराने के लिए उपयोग किया जाता है।
or

बूलियन स्थितियों के साथ एक बूलियन या ऑपरेटर के रूप में उपयोग किया जाता है। के बराबर ||

इसका उपयोग सदस्य बाधाओं में भी किया जाता है।

override एक अमूर्त या आभासी विधि के एक संस्करण को लागू करने के लिए उपयोग किया जाता है जो आधार संस्करण से भिन्न होता है।
private एक ही प्रकार या मॉड्यूल में कोड करने के लिए किसी सदस्य तक पहुंच को प्रतिबंधित करता है।
public किसी सदस्य को बाहर से टाइप करने देता है।
rec यह दर्शाता है कि एक फ़ंक्शन पुनरावर्ती है।
return एक गणना अभिव्यक्ति के परिणाम के रूप में प्रदान करने के लिए एक मूल्य को इंगित करने के लिए उपयोग किया जाता है।
return! एक अभिकलन अभिव्यक्ति को इंगित करने के लिए उपयोग किया जाता है, जब मूल्यांकन किया जाता है, जिसमें संगणना अभिव्यक्ति का परिणाम मिलता है।
select फ़ील्ड या कॉलम निकालने के लिए निर्दिष्ट करने के लिए क्वेरी अभिव्यक्तियों में उपयोग किया जाता है। ध्यान दें कि यह एक संदर्भ कीवर्ड है, जिसका अर्थ है कि यह वास्तव में एक आरक्षित शब्द नहीं है और यह केवल उचित संदर्भ में एक कीवर्ड की तरह काम करता है।
static एक विधि या संपत्ति को इंगित करने के लिए उपयोग किया जाता है जिसे एक प्रकार के उदाहरण के बिना कहा जा सकता है, या एक मूल्य सदस्य जिसे एक प्रकार के सभी उदाहरणों के बीच साझा किया जाता है।
struct

एक संरचना प्रकार घोषित करने के लिए उपयोग किया जाता है।

जेनेरिक पैरामीटर बाधाओं में भी उपयोग किया जाता है।

मॉड्यूल परिभाषाओं में OCaml संगतता के लिए उपयोग किया जाता है।

then

सशर्त अभिव्यक्तियों में प्रयुक्त।

ऑब्जेक्ट निर्माण के बाद साइड इफेक्ट्स करने के लिए भी उपयोग किया जाता है।

to एक सीमा को इंगित करने के लिए छोरों के लिए उपयोग किया जाता है।
true एक बूलियन शाब्दिक के रूप में उपयोग किया जाता है।
try कोड का एक ब्लॉक पेश करने के लिए उपयोग किया जाता है जो एक अपवाद उत्पन्न कर सकता है। साथ या अंत में एक साथ उपयोग किया जाता है ।
type एक वर्ग, रिकॉर्ड, संरचना, विभेदित संघ, गणना प्रकार, माप की इकाई या संक्षिप्त नाम घोषित करने के लिए उपयोग किया जाता है।
upcast एक प्रकार में परिवर्तित करने के लिए उपयोग किया जाता है जो वंशानुक्रम श्रृंखला में अधिक होता है।
use उन मूल्यों के लिए जाने के बजाय उपयोग किया जाता है, जिन्हें नि: शुल्क संसाधनों के लिए बुलाया जाना चाहिए।
use! चलो के बजाय इस्तेमाल किया! अतुल्यकालिक वर्कफ़्लोज़ और उन मूल्यों के लिए अन्य संगणना अभिव्यक्तियों के लिए जिन्हें नि: शुल्क संसाधनों के लिए बुलाया जाना चाहिए।
val किसी मूल्य को इंगित करने के लिए, या सीमित स्थितियों में किसी सदस्य को घोषित करने के लिए एक हस्ताक्षर में उपयोग किया जाता है।
void .NET शून्य प्रकार को इंगित करता है। अन्य .NET भाषाओं के साथ परस्पर क्रिया करते समय उपयोग किया जाता है।
when पैटर्न मिलान पर बूलियन स्थितियों (जब गार्ड) के लिए उपयोग किया जाता है और एक सामान्य प्रकार के पैरामीटर के लिए एक बाधा खंड पेश करने के लिए।
while एक लूपिंग निर्माण का परिचय देता है।
with पैटर्न मिलान अभिव्यक्ति में मैच कीवर्ड के साथ प्रयोग किया जाता है। साथ ही ऑब्जेक्ट एक्सप्रेशन, रिकॉर्ड कॉपीिंग एक्सप्रेशन और टाइप एक्सटेंशन का उपयोग सदस्य परिभाषाओं को प्रस्तुत करने के लिए, और अपवाद संचालकों को पेश करने के लिए किया जाता है।
yield एक अनुक्रम के लिए एक मूल्य का उत्पादन करने के लिए एक अनुक्रम अभिव्यक्ति में इस्तेमाल किया।
yield! एक अभिकलन अभिव्यक्ति में उपयोग किया जाता है, जिसमें दिए गए अभिकलन अभिव्यक्ति के परिणाम के संकलन के लिए एक संगणना अभिव्यक्ति का परिणाम जोड़ते हैं।

कुछ आरक्षित कीवर्ड OCaml भाषा से आए हैं -

अस्र भूमि lor LSL LSR lxor आधुनिक sig

कुछ अन्य आरक्षित कीवर्ड भविष्य में F # के विस्तार के लिए रखे गए हैं।

परमाणु टूटना जाँच अंग स्थिरांक बाधा constructor
continue eager event external fixed functor include
method mixin object parallel process protected pure
sealed tailcall trait virtual volatile

Comments in F#

F# provides two types of comments −

  • One line comment starts with // symbol.
  • Multi line comment starts with (* and ends with *).

A Basic Program and Application Entry Point in F#

Generally, you don’t have any explicit entry point for F# programs. When you compile an F# application, the last file provided to the compiler becomes the entry point and all top level statements in that file are executed from top to bottom.

A well-written program should have a single top-level statement that would call the main loop of the program.

A very minimalistic F# program that would display ‘Hello World’ on the screen −

(* This is a comment *)
(* Sample Hello World program using F# *)
printfn "Hello World!"

When you compile and execute the program, it yields the following output −

Hello World!

The data types in F# can be classified as follows −

  • Integral types
  • Floating point types
  • Text types
  • Other types

Integral Data Type

The following table provides the integral data types of F#. These are basically integer data types.

F# Type Size Range Example Remarks
sbyte 1 byte -128 to 127

42y

-11y

8-bit signed integer
byte 1 byte 0 to 255

42uy

200uy

8-bit unsigned integer
int16 2 bytes -32768 to 32767

42s

-11s

16-bit signed integer
uint16 2 bytes 0 to 65,535

42us

200us

16-bit unsigned integer
int/int32 4 bytes -2,147,483,648 to 2,147,483,647

42

-11

32-bit signed integer
uint32 4 bytes 0 to 4,294,967,295

42u

200u

32-bit unsigned integer
int64 8 bytes -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807

42L

-11L

64-bit signed integer
uint64 8 bytes 0 to 18,446,744,073,709,551,615

42UL

200UL

64-bit unsigned integer
bigint At least 4 bytes any integer

42I

1499999

9999999

9999999

9999999

9999I

arbitrary precision integer

Example

(* single byte integer *)
let x = 268.97f
let y = 312.58f
let z = x + y

printfn "x: %f" x
printfn "y: %f" y
printfn "z: %f" z

(* unsigned 8-bit natural number *)

let p = 2uy
let q = 4uy
let r = p + q

printfn "p: %i" p
printfn "q: %i" q
printfn "r: %i" r

(* signed 16-bit integer *)

let a = 12s
let b = 24s
let c = a + b

printfn "a: %i" a
printfn "b: %i" b
printfn "c: %i" c

(* signed 32-bit integer *)

let d = 212l
let e = 504l
let f = d + e

printfn "d: %i" d
printfn "e: %i" e
printfn "f: %i" f

When you compile and execute the program, it yields the following output −

x: 1
y: 2
z: 3
p: 2
q: 4
r: 6
a: 12
b: 24
c: 36
d: 212
e: 504
f: 716

Floating Point Data Types

The following table provides the floating point data types of F#.

F# Type Size Range Example Remarks
float32 4 bytes ±1.5e-45 to ±3.4e38

42.0F

-11.0F

32-bit signed floating point number (7 significant digits)
float 8 bytes ±5.0e-324 to ±1.7e308

42.0

-11.0

64-bit signed floating point number (15-16 significant digits)
decimal 16 bytes ±1.0e-28 to ±7.9e28

42.0M

-11.0M

128-bit signed floating point number (28-29 significant digits)
BigRational At least 4 bytes Any rational number.

42N

-11N

Arbitrary precision rational number. Using this type requires a reference to FSharp.PowerPack.dll.

Example

(* 32-bit signed floating point number *)
(* 7 significant digits *)

let d = 212.098f
let e = 504.768f
let f = d + e

printfn "d: %f" d
printfn "e: %f" e
printfn "f: %f" f

(* 64-bit signed floating point number *)
(* 15-16 significant digits *)
let x = 21290.098
let y = 50446.768
let z = x + y

printfn "x: %g" x
printfn "y: %g" y
printfn "z: %g" z

When you compile and execute the program, it yields the following output −

d: 212.098000
e: 504.768000
f: 716.866000
x: 21290.1
y: 50446.8
z: 71736.9

Text Data Types

The following table provides the text data types of F#.

F# Type Size Range Example Remarks
char 2 bytes U+0000 to U+ffff

'x'

'\t'

Single unicode characters
string 20 + (2 * string's length) bytes 0 to about 2 billion characters

"Hello"

"World"

Unicode text

Example

let choice = 'y'
let name = "Zara Ali"
let org = "Tutorials Point"

printfn "Choice: %c" choice
printfn "Name: %s" name
printfn "Organisation: %s" org

When you compile and execute the program, it yields the following output −

Choice: y
Name: Zara Ali
Organisation: Tutorials Point

Other Data Types

The following table provides some other data types of F#.

F# Type Size Range Example Remarks
bool 1 byte Only two possible values, true or false

true

false

Stores boolean values

Example

let trueVal = true
let falseVal = false

printfn "True Value: %b" (trueVal)
printfn "False Value: %b" (falseVal)

When you compile and execute the program, it yields the following output −

True Value: true
False Value: false

A variable is a name given to a storage area that our programs can manipulate. Each variable has a specific type, which determines the size and layout of the variable's memory; the range of values that can be stored within that memory; and the set of operations that can be applied to the variable.

Variable Declaration in F#

The let keyword is used for variable declaration −

For example,

let x = 10

It declares a variable x and assigns the value 10 to it.

You can also assign an expression to a variable −

let x = 10
let y = 20
let z = x + y

The following example illustrates the concept −

Example

let x = 10
let y = 20
let z = x + y

printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

When you compile and execute the program, it yields the following output −

x: 10
y: 20
z: 30

Variables in F# are immutable, which means once a variable is bound to a value, it can’t be changed. They are actually compiled as static read-only properties.

The following example demonstrates this.

Example

let x = 10
let y = 20
let z = x + y

printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

let x = 15
let y = 20
let z = x + y

printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

When you compile and execute the program, it shows the following error message −

Duplicate definition of value 'x'
Duplicate definition of value 'Y'
Duplicate definition of value 'Z'

Variable Definition With Type Declaration

A variable definition tells the compiler where and how much storage for the variable should be created. A variable definition may specify a data type and contains a list of one or more variables of that type as shown in the following example.

Example

let x:int32 = 10
let y:int32 = 20
let z:int32 = x + y

printfn "x: %d" x
printfn "y: %d" y
printfn "z: %d" z

let p:float = 15.99
let q:float = 20.78
let r:float = p + q

printfn "p: %g" p
printfn "q: %g" q
printfn "r: %g" r

When you compile and execute the program, it shows the following error message −

x: 10
y: 20
z: 30
p: 15.99
q: 20.78
r: 36.77

Mutable Variables

At times you need to change the values stored in a variable. To specify that there could be a change in the value of a declared and assigned variable, in later part of a program, F# provides the mutable keyword. You can declare and assign mutable variables using this keyword, whose values you will change.

The mutable keyword allows you to declare and assign values in a mutable variable.

You can assign some initial value to a mutable variable using the let keyword. However, to assign new subsequent value to it, you need to use the operator.

For example,

let mutable x = 10
x ← 15

The following example will clear the concept −

Example

let mutable x = 10
let y = 20
let mutable z = x + y

printfn "Original Values:"
printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

printfn "Let us change the value of x"
printfn "Value of z will change too."

x <- 15
z <- x + y

printfn "New Values:"
printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

When you compile and execute the program, it yields the following output −

Original Values:
x: 10
y: 20
z: 30
Let us change the value of x
Value of z will change too.
New Values:
x: 15
y: 20
z: 35

An operator is a symbol that tells the compiler to perform specific mathematical or logical manipulations. F# is rich in built-in operators and provides the following types of operators −

  • Arithmetic Operators
  • Comparison Operators
  • Boolean Operators
  • Bitwise Operators

Arithmetic Operators

The following table shows all the arithmetic operators supported by F# language. Assume variable A holds 10 and variable B holds 20 then −

Show Example

Operator Description Example
+ Adds two operands A + B will give 30
- Subtracts second operand from the first A - B will give -10
* Multiplies both operands A * B will give 200
/ Divides numerator by de-numerator B / A will give 2
% Modulus Operator and remainder of after an integer division B % A will give 0
** Exponentiation Operator, raises an operand to the power of another B**A will give 2010

Comparison Operators

The following table shows all the comparison operators supported by F# language. These binary comparison operators are available for integral and floating-point types. These operators return values of type bool.

Assume variable A holds 10 and variable B holds 20, then −

Show Example

Operator Description Example
= Checks if the values of two operands are equal or not, if yes then condition becomes true. (A == B) is not true.
<> Checks if the values of two operands are equal or not, if values are not equal then condition becomes true. (A <> B) is true.
> Checks if the value of left operand is greater than the value of right operand, if yes then condition becomes true. (A > B) is not true.
< Checks if the value of left operand is less than the value of right operand, if yes then condition becomes true. (A < B) is true.
>= Checks if the value of left operand is greater than or equal to the value of right operand, if yes then condition becomes true. (A >= B) is not true.
<= Checks if the value of left operand is less than or equal to the value of right operand, if yes then condition becomes true. (A <= B) is true.

Boolean Operators

The following table shows all the Boolean operators supported by F# language. Assume variable A holds true and variable B holds false, then −

Show Example

Operator Description Example
&& Called Boolean AND operator. If both the operands are non-zero, then condition becomes true. (A && B) is false.
|| Called Boolean OR Operator. If any of the two operands is non-zero, then condition becomes true. (A || B) is true.
not Called Boolean NOT Operator. Use to reverses the logical state of its operand. If a condition is true then Logical NOT operator will make false. not (A && B) is true.

Bitwise Operators

Bitwise operators work on bits and perform bit-by-bit operation. The truth tables for &&& (bitwise AND), ||| (bitwise OR), and ^^^ (bitwise exclusive OR) are as follows −

Show Example

p q p &&& q p ||| q p ^^^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

Assume if A = 60; and B = 13; now in binary format they will be as follows −

A = 0011 1100

B = 0000 1101

A&&&B = 0000 1100

A|||B = 0011 1101

A^^^B = 0011 0001

~~~A = 1100 0011

The Bitwise operators supported by F# language are listed in the following table. Assume variable A holds 60 and variable B holds 13, then −

Operator Description Example
&&& Binary AND Operator copies a bit to the result if it exists in both operands. (A &&& B) will give 12, which is 0000 1100
||| Binary OR Operator copies a bit if it exists in either operand. (A ||| B) will give 61, which is 0011 1101
^^^ Binary XOR Operator copies the bit if it is set in one operand but not both. (A ^^^ B) will give 49, which is 0011 0001
~~~ Binary Ones Complement Operator is unary and has the effect of 'flipping' bits. (~~~A) will give -61, which is 1100 0011 in 2's complement form.
<<< Binary Left Shift Operator. The left operands value is moved left by the number of bits specified by the right operand. A <<< 2 will give 240 which is 1111 0000
>>> Binary Right Shift Operator. The left operands value is moved right by the number of bits specified by the right operand. A >>> 2 will give 15 which is 0000 1111

Operators Precedence

The following table shows the order of precedence of operators and other expression keywords in the F# language, from lowest precedence to the highest precedence.

Show Example

Operator Associativity
as Right
when Right
| (pipe) Left
; Right
let Non associative
function, fun, match, try Non associative
if Non associative
Right
:= Right
, Non associative
or, || Left
&, && Left
< op, >op, =, |op, &op Left
&&& , |||, ^^^, ~~~, <<<, >>> Left
^ op Right
:: Right
:?>, :? Non associative
- op, +op, (binary) Left
* op, /op, %op Left
** op Right
f x (function application) Left
| (pattern match) Right
prefix operators (+op, -op, %, %%, &, &&, !op, ~op) Left
. Left
f(x) Left
f<types> Left

Decision making structures require that the programmer specify one or more conditions to be evaluated or tested by the program. It should be along with a statement or statements to be executed if the condition is determined to be true, and optionally, other statements to be executed if the condition is determined to be false.

Following is the general form of a typical decision making structure found in most of the programming languages −

F# programming language provides the following types of decision making statements.

Statement Description
if /then statement An if/then statement consists of a Boolean expression followed by one or more statements.
if/then/ else statement An if/then statement can be followed by an optional else statement, which executes when the Boolean expression is false.
if/then/elif/else statement An if/then/elif/else statement allows you to have multiple else branches.
nested if statements You can use one if or else if statement inside another if or else if statement(s).

Programming languages provide various control structures that allow for more complicated execution paths.

A loop statement allows us to execute a statement or group of statements multiple times and following is the general form of a loop statement in most of the programming languages −

F# provides the following types of loops to handle the looping requirements.

Loop Type Description
for… to and for… downto expressions The for...to expression is used to iterate in a loop over a range of values of a loop variable. The for… downto expression reduces the value of loop variable.
for … in expression This form of for loop is used to iterate over collections of items i.e., loops over collections and sequences
While…do loop Repeats a statement or group of statements while a given condition is true. It tests the condition before executing the loop body.
nested loops You can use one or more loop inside any other for or while loop.

In F#, functions work like data types. You can declare and use a function in the same way like any other variable.

Since functions can be used like any other variables, you can −

  • Create a function, with a name and associate that name with a type.
  • Assign it a value.
  • Perform some calculation on that value.
  • Pass it as a parameter to another function or sub-routine.
  • Return a function as the result of another function.

Defining a Function

Functions are defined by using the let keyword. A function definition has the following syntax −

let [inline] function-name parameter-list [ : return-type ]
= function-body

Where,

  • function-name is an identifier that represents the function.

  • parameter-list gives the list of parameters separated by spaces. You can also specify an explicit type for each parameter and if not specified compiler tends to deduce it from the function body (like variables).

  • function-body consists of an expression, or a compound expression consisting of a number of expressions. The final expression in the function body is the return value.

  • return-type is a colon followed by a type and is optional. If the return type is not specified, then the compiler determines it from the final expression in the function body.

Parameters of a Function

You list the names of parameters right after the function name. You can specify the type of a parameter. The type of the parameter should follow the name of the parameter separated by a colon.

If no parameter type is specified, it is inferred by the compiler.

For example −

let doubleIt (x : int) = 2 * x

Calling a Function

A function is called by specifying the function name followed by a space and then any arguments separated by spaces.

For example −

let vol = cylinderVolume 3.0 5.0

The following programs illustrate the concepts.

Example 1

The following program calculates the volume of a cylinder when the radius and length are given as parameters

// the function calculates the volume of
// a cylinder with radius and length as parameters

let cylinderVolume radius length : float =

   // function body
   let pi = 3.14159
   length * pi * radius * radius

let vol = cylinderVolume 3.0 5.0
printfn " Volume: %g " vol

When you compile and execute the program, it yields the following output −

Volume: 141.372

Example 2

The following program returns the larger value of two given parameters −

// the function returns the larger value between two
// arguments

let max num1 num2 : int32 =
   // function body
   if(num1>num2)then
      num1
   else
      num2

let res = max 39 52
printfn " Max Value: %d " res

When you compile and execute the program, it yields the following output −

Max Value: 52

Example 3

let doubleIt (x : int) = 2 * x
printfn "Double 19: %d" ( doubleIt(19))

When you compile and execute the program, it yields the following output −

Double 19: 38

Recursive Functions

Recursive functions are functions that call themselves.

You define a recursive using the let rec keyword combination.

Syntax for defining a recursive function is −

//Recursive function definition
let rec function-name parameter-list = recursive-function-body

For example −

let rec fib n = if n < 2 then 1 else fib (n - 1) + fib (n - 2)

Example 1

The following program returns Fibonacci 1 to 10 −

let rec fib n = if n < 2 then 1 else fib (n - 1) + fib (n - 2)
for i = 1 to 10 do
   printfn "Fibonacci %d: %d" i (fib i)

When you compile and execute the program, it yields the following output −

Fibonacci 1: 1
Fibonacci 2: 2
Fibonacci 3: 3
Fibonacci 4: 5
Fibonacci 5: 8
Fibonacci 6: 13
Fibonacci 7: 21
Fibonacci 8: 34
Fibonacci 9: 55
Fibonacci 10: 89

Example 2

The following program returns factorial 8 −

open System
let rec fact x =
   if x < 1 then 1
   else x * fact (x - 1)
Console.WriteLine(fact 8)

When you compile and execute the program, it yields the following output −

40320

Arrow Notations in F#

F# reports about data type in functions and values, using a chained arrow notation. Let us take an example of a function that takes one int input, and returns a string. In arrow notation, it is written as −

int -> string

Data types are read from left to right.

Let us take another hypothetical function that takes two int data inputs and returns a string.

let mydivfunction x y = (x / y).ToString();;

F# reports the data type using chained arrow notation as −

val mydivfunction : x:int -> y:int -> string

The return type is represented by the rightmost data type in chained arrow notation.

Some more examples −

Notation Meaning
float → float → float The function takes two float inputs, returns another float.
int → string → float The function takes an int and a string input, returns a float.

Lambda Expressions

A lambda expression is an unnamed function.

Let us take an example of two functions −

let applyFunction ( f: int -> int -> int) x y = f x y
let mul x y = x * y
let res = applyFunction mul 5 7
printfn "%d" res

When you compile and execute the program, it yields the following output −

35

Now in the above example, if instead of defining the function mul, we could have used lambda expressions as −

let applyFunction ( f: int -> int -> int) x y = f x y
let res = applyFunction (fun x y -> x * y ) 5 7
printfn "%d" res

When you compile and execute the program, it yields the following output −

35

Function Composition and Pipelining

In F#, one function can be composed from other functions.

The following example shows the composition of a function named f, from two functions function1 and function2 −

let function1 x = x + 1
let function2 x = x * 5

let f = function1 >> function2
let res = f 10
printfn "%d" res

When you compile and execute the program, it yields the following output −

55

F# also provides a feature called pipelining of functions. Pipelining allows function calls to be chained together as successive operations.

The following example shows that −

let function1 x = x + 1
let function2 x = x * 5

let res = 10 |> function1 |> function2
printfn "%d" res

When you compile and execute the program, it yields the following output −

55

In F#, the string type represents immutable text as a sequence of Unicode characters.

String Literals

String literals are delimited by the quotation mark (") character.

Some special characters are there for special uses like newline, tab, etc. They are encoded using backslash (\) character. The backslash character and the related character make the escape sequence. The following table shows the escape sequence supported by F#.

Character Escape sequence
Backspace \b
Newline \n
Carriage return \r
Tab \t
Backslash \\
Quotation mark \"
Apostrophe \'
Unicode character \uXXXX or \UXXXXXXXX (where X indicates a hexadecimal digit)

Ways of lgnoring the Escape Sequence

The following two ways makes the compiler ignore the escape sequence −

  • Using the @ symbol.
  • Enclosing the string in triple quotes.

When a string literal is preceded by the @ symbol, it is called a verbatim string. In that way, all escape sequences in the string are ignored, except that two quotation mark characters are interpreted as one quotation mark character.

When a string is enclosed by triple quotes, then also all escape sequences are ignored, including double quotation mark characters.

Example

The following example demonstrates this technique showing how to work with XML or other structures that include embedded quotation marks −

// Using a verbatim string
let xmldata = @"<book author=""Lewis, C.S"" title=""Narnia"">"
printfn "%s" xmldata

When you compile and execute the program, it yields the following output −

<book author="Lewis, C.S" title="Narnia">

Basic Operators on Strings

The following table shows the basic operations on strings −

Value Description
collect : (char → string) → string → string Creates a new string whose characters are the results of applying a specified function to each of the characters of the input string and concatenating the resulting strings.
concat : string → seq<string> → string Returns a new string made by concatenating the given strings with a separator.
exists : (char → bool) → string → bool Tests if any character of the string satisfies the given predicate.
forall : (char → bool) → string → bool Tests if all characters in the string satisfy the given predicate.
init : int → (int → string) → string Creates a new string whose characters are the results of applying a specified function to each index and concatenating the resulting strings.
iter : (char → unit) → string → unit Applies a specified function to each character in the string.
iteri : (int → char → unit) → string → unit Applies a specified function to the index of each character in the string and the character itself.
length : string → int Returns the length of the string.
map : (char → char) → string → string Creates a new string whose characters are the results of applying a specified function to each of the characters of the input string.
mapi : (int → char → char) → string → string Creates a new string whose characters are the results of applying a specified function to each character and index of the input string.
replicate : int → string → string Returns a string by concatenating a specified number of instances of a string.

The following examples demonstrate the uses of some of the above functionalities −

Example 1

The String.collect function builds a new string whose characters are the results of applying a specified function to each of the characters of the input string and concatenating the resulting strings.

let collectTesting inputS =
   String.collect (fun c -> sprintf "%c " c) inputS
printfn "%s" (collectTesting "Happy New Year!")

When you compile and execute the program, it yields the following output −

H a p p y N e w Y e a r !

Example 2

The String.concat function concatenates a given sequence of strings with a separator and returns a new string.

let strings = [ "Tutorials Point"; "Coding Ground"; "Absolute Classes" ]
let ourProducts = String.concat "\n" strings
printfn "%s" ourProducts

When you compile and execute the program, it yields the following output −

Tutorials Point
Coding Ground
Absolute Classes

Example 3

The String.replicate method returns a string by concatenating a specified number of instances of a string.

printfn "%s" <| String.replicate 10 "*! "

When you compile and execute the program, it yields the following output −

*! *! *! *! *! *! *! *! *! *!

The option type in F# is used in calculations when there may or may not exist a value for a variable or function. Option types are used for representing optional values in calculations. They can have two possible values − Some(x) or None.

For example, a function performing a division will return a value in normal situation, but will throw exceptions in case of a zero denominator. Using options here will help to indicate whether the function has succeeded or failed.

An option has an underlying type and can hold a value of that type, or it might not have a value.

Using Options

Let us take the example of division function. The following program explains this −

Let us write a function div, and send two arguments to it 20 and 5 −

let div x y = x / y
let res = div 20 5
printfn "Result: %d" res

When you compile and execute the program, it yields the following output −

Result: 4

If the second argument is zero, then the program throws an exception −

let div x y = x / y
let res = div 20 0
printfn "Result: %d" res

When you compile and execute the program, it yields the following output −

Unhandled Exception:
System.DivideByZeroException: Division by zero

In such cases, we can use option types to return Some (value) when the operation is successful or None if the operation fails.

The following example demonstrates the use of options −

Example

let div x y =
   match y with
   | 0 -> None
   | _ -> Some(x/y)

let res : int option = div 20 4
printfn "Result: %A " res

When you compile and execute the program, it yields the following output −

Result: Some 5

Option Properties and Methods

The option type supports the following properties and methods −

Property or method Type Description
None 'T option A static property that enables you to create an option value that has the None value.
IsNone bool Returns true if the option has the None value.
IsSome bool Returns true if the option has a value that is not None.
Some 'T option A static member that creates an option that has a value that is not None.
Value 'T Returns the underlying value, or throws a NullReferenceException if the value is None.

Example 1

let checkPositive (a : int) =
   if a > 0 then
      Some(a)
   else
      None

let res : int option = checkPositive(-31)
printfn "Result: %A " res

When you compile and execute the program, it yields the following output −

Result: <null>

Example 2

let div x y =
   match y with
   | 0 -> None
   | _ -> Some(x/y)

let res : int option = div 20 4
printfn "Result: %A " res
printfn "Result: %A " res.Value

When you compile and execute the program, it yields the following output −

Result: Some 5
Result: 5

Example 3

let isHundred = function
   | Some(100) -> true
   | Some(_) | None -> false

printfn "%A" (isHundred (Some(45)))
printfn "%A" (isHundred (Some(100)))
printfn "%A" (isHundred None)

When you compile and execute the program, it yields the following output −

false
true
false

tupleमूल्यों का अल्पविराम से अलग संग्रह है। इनका उपयोग तदर्थ डेटा संरचनाओं को बनाने के लिए किया जाता है, जो संबंधित मूल्यों को एक साथ समूहित करते हैं।

उदाहरण के लिए, ("ज़ारा अली", "हैदराबाद", 10) दो स्ट्रिंग मूल्यों और एक इंट वैल्यू के साथ एक 3-ट्यूपल है, इसमें टाइप (स्ट्रिंग * स्ट्रिंग * इंट) है।

ट्यूपल्स एक ही या अलग-अलग प्रकार के जोड़े, ट्रिपल्स आदि हो सकते हैं।

कुछ उदाहरण यहाँ दिए गए हैं -

// Tuple of two integers.
( 4, 5 )

// Triple of strings.
( "one", "two", "three" )

// Tuple of unknown types.
( a, b )

// Tuple that has mixed types.
( "Absolute Classes", 1, 2.0 )

// Tuple of integer expressions.
( a * 4, b + 7)

उदाहरण

इस कार्यक्रम में एक फ़ंक्शन होता है जो चार फ्लोट मानों का एक हिस्सा लेता है और औसत लौटाता है -

let averageFour (a, b, c, d) =
   let sum = a + b + c + d
   sum / 4.0

let avg:float = averageFour (4.0, 5.1, 8.0, 12.0)
printfn "Avg of four numbers: %f" avg

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

Avg of four numbers: 7.275000

व्यक्तिगत टपल सदस्यों तक पहुँचना

ट्यूपल के अलग-अलग सदस्यों का मूल्यांकन और मिलान पैटर्न का उपयोग करके मुद्रित किया जा सकता है।

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

उदाहरण

let display tuple1 =
   match tuple1 with
   | (a, b, c) -> printfn "Detail Info: %A %A %A" a b c

display ("Zara Ali", "Hyderabad", 10 )

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

Detail Info: "Zara Ali" "Hyderabad" 10

F # में दो अंतर्निहित कार्य हैं, fst तथा snd, जो 2-ट्यूपल में पहले और दूसरे आइटम को लौटाता है।

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

उदाहरण

printfn "First member: %A" (fst(23, 30))
printfn "Second member: %A" (snd(23, 30))

printfn "First member: %A" (fst("Hello", "World!"))
printfn "Second member: %A" (snd("Hello", "World!"))

let nameTuple = ("Zara", "Ali")

printfn "First Name: %A" (fst nameTuple)
printfn "Second Name: %A" (snd nameTuple)

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

First member: 23
Second member: 30
First member: "Hello"
Second member: "World!"
First Name: "Zara"
Second Name: "Ali"

recordएक टपल के समान है, हालांकि इसमें नाम वाले क्षेत्र शामिल हैं। उदाहरण के लिए,

type website =
   { title : string;
      url : string }

रिकॉर्ड को परिभाषित करना

एक रिकॉर्ड को एक प्रकार के रूप में परिभाषित किया गया है type कीवर्ड, और रिकॉर्ड के क्षेत्रों को अर्धविराम से अलग की गई सूची के रूप में परिभाषित किया गया है।

एक रिकॉर्ड को परिभाषित करने के लिए सिंटैक्स है -

type recordName =
   { [ fieldName : dataType ] + }

एक रिकॉर्ड बनाना

आप रिकॉर्ड के क्षेत्रों को निर्दिष्ट करके एक रिकॉर्ड बना सकते हैं। उदाहरण के लिए, हम होमपेज नाम से एक वेबसाइट रिकॉर्ड बनाते हैं -

let homepage = { Title = "TutorialsPoint"; Url = "www.tutorialspoint.com" }

निम्नलिखित उदाहरण अवधारणाओं की व्याख्या करेंगे -

उदाहरण 1

यह कार्यक्रम एक रिकॉर्ड प्रकार की वेबसाइट को परिभाषित करता है। फिर यह टाइप वेबसाइट के कुछ रिकॉर्ड बनाता है और रिकॉर्ड प्रिंट करता है।

(* defining a record type named website *)
type website =
   { Title : string;
      Url : string }

(* creating some records *)
let homepage = { Title = "TutorialsPoint"; Url = "www.tutorialspoint.com" }
let cpage = { Title = "Learn C"; Url = "www.tutorialspoint.com/cprogramming/index.htm" }
let fsharppage = { Title = "Learn F#"; Url = "www.tutorialspoint.com/fsharp/index.htm" }
let csharppage = { Title = "Learn C#"; Url = "www.tutorialspoint.com/csharp/index.htm" }

(*printing records *)
(printfn "Home Page: Title: %A \n \t URL: %A") homepage.Title homepage.Url
(printfn "C Page: Title: %A \n \t URL: %A") cpage.Title cpage.Url
(printfn "F# Page: Title: %A \n \t URL: %A") fsharppage.Title fsharppage.Url
(printfn "C# Page: Title: %A \n \t URL: %A") csharppage.Title csharppage.Url

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

Home Page: Title: "TutorialsPoint"
       URL: "www.tutorialspoint.com"
C Page: Title: "Learn C"
      URL: "www.tutorialspoint.com/cprogramming/index.htm"
F# Page: Title: "Learn F#"
      URL: "www.tutorialspoint.com/fsharp/index.htm"
C# Page: Title: "Learn C#"
      URL: "www.tutorialspoint.com/csharp/index.htm"

उदाहरण 2

type student =
   { Name : string;
      ID : int;
      RegistrationText : string;
      IsRegistered : bool }

let getStudent name id =
   { Name = name; ID = id; RegistrationText = null; IsRegistered = false }

let registerStudent st =
   { st with
      RegistrationText = "Registered";
      IsRegistered = true }

let printStudent msg st =
   printfn "%s: %A" msg st

let main() =
   let preRegisteredStudent = getStudent "Zara" 10
   let postRegisteredStudent = registerStudent preRegisteredStudent

   printStudent "Before Registration: " preRegisteredStudent
   printStudent "After Registration: " postRegisteredStudent

main()

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

Before Registration: : {Name = "Zara";
   ID = 10;
   RegistrationText = null;
   IsRegistered = false;}
After Registration: : {Name = "Zara";
   ID = 10;
   RegistrationText = "Registered";
   IsRegistered = true;}

F # में, एक सूची उसी प्रकार के तत्वों की एक क्रमबद्ध, अपरिवर्तनीय श्रृंखला है। यह कुछ हद तक एक लिंक्ड सूची डेटा संरचना के बराबर है।

एफ # मॉड्यूल, Microsoft.FSharp.Collections.List,सूचियों पर आम संचालन है। हालाँकि F # इस मॉड्यूल को स्वचालित रूप से आयात करता है और इसे हर F # एप्लिकेशन के लिए सुलभ बनाता है।

सूची बनाना और आरंभ करना

सूची बनाने के विभिन्न तरीके निम्नलिखित हैं -

  • सूची का उपयोग करना literals

  • का उपयोग करते हुए cons (::) ऑपरेटर।

  • का उपयोग करते हुए List.init सूची मॉड्यूल की विधि।

  • कुछ का उपयोग करना syntactic constructs बुलाया List Comprehensions

सूची का साहित्य

इस विधि में, आप वर्गाकार कोष्ठक में मानों के अर्धविराम-सीमांकित अनुक्रम को निर्दिष्ट करते हैं। उदाहरण के लिए -

let list1 = [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]

विपक्ष (: :) ऑपरेटर

इस विधि से, आप कुछ मानों को जोड़कर या जोड़कर देख सकते हैं cons-ingएक मौजूदा सूची में इसका उपयोग :: ऑपरेटर। उदाहरण के लिए -

let list2 = 1::2::3::4::5::6::7::8::9::10::[];;

[] एक खाली सूची को दर्शाता है।

सूची विधि

सूची बनाने के लिए सूची मॉड्यूल की List.init विधि का उपयोग अक्सर किया जाता है। इस विधि का प्रकार है -

val init : int -> (int -> 'T) -> 'T list

पहला तर्क नई सूची की वांछित लंबाई है, और दूसरा तर्क एक प्रारंभिक कार्य है, जो सूची में आइटम उत्पन्न करता है।

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

let list5 = List.init 5 (fun index -> (index, index * index, index * index * index))

यहां, इंडेक्स फ़ंक्शन सूची बनाता है।

सूची की समझ

सूची बोधक सूची बनाने के लिए उपयोग किए जाने वाले विशेष वाक्य रचना हैं।

F # लिस्ट कॉम्प्रिहेंशन सिंटैक्स दो रूपों में आता है - रेंज और जनरेटर।

सीमाओं में निर्माण होते हैं - [प्रारंभ .. अंत] और [प्रारंभ .. चरण .. अंत]

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

let list3 = [1 .. 10]

जनरेटर का निर्माण होता है - [एक्स फॉर कलेक्शन करते हैं ... उपज एक्सप]

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

let list6 = [ for a in 1 .. 10 do yield (a * a) ]

के रूप में yield कीवर्ड सूची में एकल मान को धक्का देता है, कीवर्ड, yield!, सूची में मूल्यों के संग्रह को धक्का देता है।

निम्नलिखित कार्य उपरोक्त विधियों को प्रदर्शित करता है -

उदाहरण

(* using list literals *)
let list1 = [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
printfn "The list: %A" list1

(*using cons operator *)
let list2 = 1 :: 2 :: 3 :: []
printfn "The list: %A" list2

(* using range constructs*)
let list3 = [1 .. 10]
printfn "The list: %A" list3

(* using range constructs *)
let list4 = ['a' .. 'm']
printfn "The list: %A" list4

(* using init method *)
let list5 = List.init 5 (fun index -> (index, index * index, index * index * index))
printfn "The list: %A" list5

(* using yield operator *)
let list6 = [ for a in 1 .. 10 do yield (a * a) ]
printfn "The list: %A" list6

(* using yield operator *)
let list7 = [ for a in 1 .. 100 do if a % 3 = 0 && a % 5 = 0 then yield a]
printfn "The list: %A" list7

(* using yield! operator *)
let list8 = [for a in 1 .. 3 do yield! [ a .. a + 3 ] ]
printfn "The list: %A" list8

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

The list: [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
The list: [1; 2; 3]
The list: [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
The list: ['a'; 'b'; 'c'; 'd'; 'e'; 'f'; 'g'; 'h'; 'i'; 'j'; 'k'; 'l'; 'm']
The list: [(0, 0, 0); (1, 1, 1); (2, 4, 8); (3, 9, 27); (4, 16, 64)]
The list: [1; 4; 9; 16; 25; 36; 49; 64; 81; 100]
The list: [15; 30; 45; 60; 75; 90]
The list: [1; 2; 3; 4; 2; 3; 4; 5; 3; 4; 5; 6]

सूची डेटा प्रकार के गुण

निम्न तालिका सूची डेटा प्रकार के विभिन्न गुणों को दिखाती है -

संपत्ति प्रकार विवरण
सिर 'टी पहला तत्व।
खाली 'टी सूची एक स्थिर संपत्ति जो उपयुक्त प्रकार की एक खाली सूची लौटाती है।
खाली है bool true यदि सूची में कोई तत्व नहीं है।
मद 'टी निर्दिष्ट सूचकांक (शून्य-आधारित) पर तत्व।
लंबाई पूर्णांक तत्वों की संख्या।
पूंछ 'टी सूची पहले तत्व के बिना सूची।

निम्न उदाहरण इन गुणों के उपयोग को दर्शाता है -

उदाहरण

let list1 = [ 2; 4; 6; 8; 10; 12; 14; 16 ]

// Use of Properties
printfn "list1.IsEmpty is %b" (list1.IsEmpty)
printfn "list1.Length is %d" (list1.Length)
printfn "list1.Head is %d" (list1.Head)
printfn "list1.Tail.Head is %d" (list1.Tail.Head)
printfn "list1.Tail.Tail.Head is %d" (list1.Tail.Tail.Head)
printfn "list1.Item(1) is %d" (list1.Item(1))

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

list1.IsEmpty is false
list1.Length is 8
list1.Head is 2
list1.Tail.Head is 4
list1.Tail.Tail.Head is 6
list1.Item(1) is 4

सूची पर मूल संचालक

निम्न तालिका सूची डेटा प्रकार पर बुनियादी संचालन दिखाती है -

मूल्य विवरण
परिशिष्ट: 'टी सूची →' टी सूची → 'टी सूची एक नई सूची लौटाता है जिसमें पहली सूची के तत्व होते हैं और उसके बाद दूसरे तत्व होते हैं।
औसत: 'टी सूची → ^ टी सूची में तत्वों का औसत लौटाता है।
औसतन: ('T → ^ U) →' T सूची → ^ U सूची के प्रत्येक तत्व में फ़ंक्शन को लागू करके उत्पन्न तत्वों का औसत लौटाता है।
चुनें: ('T →' U विकल्प) → 'T सूची →' U सूची दिए गए फ़ंक्शन को सूची के प्रत्येक तत्व पर लागू करता है। प्रत्येक तत्व के लिए परिणामों में शामिल सूची लौटाता है जहाँ फ़ंक्शन लौटता हैSome
एकत्र: ('टी →' यू सूची) → 'टी सूची →' यू सूची सूची के प्रत्येक तत्व के लिए, दिए गए फ़ंक्शन को लागू करता है। सभी परिणामों को सम्मिलित करता है और संयुक्त सूची लौटाता है।
concat: seq <'T list> →' T सूची एक नई सूची देता है जिसमें क्रम में प्रत्येक सूची के तत्व शामिल होते हैं।
रिक्त: 'टी सूची दिए गए प्रकार की एक खाली सूची देता है।
मौजूद है: ('टी → बूल) →' टी सूची → बूल टेस्ट यदि सूची का कोई तत्व दिए गए विधेय को संतुष्ट करता है।
मौजूद 2: ('T1 →' T2 → बूल) → 'T1 सूची →' T2 सूची → बूल यदि सूचियों के संगत तत्वों में से कोई भी युग्म दिए गए विधेय को संतुष्ट करता है तो टेस्ट।
फ़िल्टर: ('टी → बूल) →' टी सूची → 'टी सूची एक नया संग्रह लौटाता है जिसमें संग्रह के केवल तत्व होते हैं जिसके लिए दिए गए विधेय रिटर्न देता है true
खोजें: ('टी → बूल) →' टी सूची → 'टी पहला तत्व लौटाता है जिसके लिए दिए गए फ़ंक्शन देता है true
findIndex: ('टी → बूल) →' टी सूची → इंट सूची में पहले तत्व के सूचकांक को लौटाता है जो दिए गए विधेय को संतुष्ट करता है।
तह: ('राज्य →' टी → 'राज्य) →' राज्य → 'टी सूची →' राज्य संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाता है। यह फ़ंक्शन दूसरा तर्क लेता है, और फ़ंक्शन को इसे और सूची के पहले तत्व पर लागू करता है। फिर, यह दूसरे तत्व के साथ फ़ंक्शन में इस परिणाम को पारित करता है, और इसी तरह। अंत में, यह अंतिम परिणाम देता है। यदि इनपुट फ़ंक्शन f है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (fs i0) i1 ...) iN गणना करता है।
fold2: ('State →' T1 → 'T2 →' State) → 'State →' T1 सूची → 'T2 → →' State एक संग्रह के दो तत्वों के लिए एक फ़ंक्शन को लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। संग्रह में समान आकार होने चाहिए। यदि इनपुट फ़ंक्शन f है और एलिमेंट्स i0 ... iN और j0 ... jN हैं, तो यह फ़ंक्शन f (... (fs i0 j0) ...) iN jN है।
foldBack: ('T →' State → 'State) →' T list → 'State →' State संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाता है। यदि इनपुट फ़ंक्शन isf और एलिमेंट्स i0 ... iN है तो f i0 (... (f iN s)) की गणना करता है।
foldBack2: ('T1 →' T2 → 'राज्य →' राज्य) → 'T1 सूची →' T2 सूची → 'राज्य →' राज्य एक संग्रह के दो तत्वों के लिए एक फ़ंक्शन को लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। संग्रह में समान आकार होने चाहिए। यदि इनपुट फ़ंक्शन f है और एलिमेंट्स i0 ... iN और j0 ... jN हैं, तो यह फ़ंक्शन f i0 j0 (... (f iN jN s)) की गणना करता है।
forall: ('टी → बूल) →' टी सूची → बूल टेस्ट अगर संग्रह के सभी तत्व दिए गए विधेय को संतुष्ट करते हैं।
forall2: ('T1 →' T2 → बूल) → 'T1 सूची →' T2 सूची → बूल टेस्ट अगर संग्रह के सभी संबंधित तत्व दिए गए विधेय को संतुष्ट करते हैं।
सिर: 'टी सूची →' टी सूची का पहला तत्व लौटाता है।
init: int → (int → 'T) →' T सूची प्रत्येक इंडेक्स पर दिए गए जनरेटर को कॉल करके एक सूची बनाता है।
isEmpty: 'T सूची → बूल रिटर्न true यदि सूची में कोई तत्व नहीं है, false अन्यथा।
पुनरावृति: ('T → इकाई) →' T सूची → इकाई संग्रह के प्रत्येक तत्व के लिए दिए गए फ़ंक्शन को लागू करता है।
iter2: ('T1 →' T2 → इकाई) → 'T1 सूची →' T2 सूची → इकाई दिए गए फ़ंक्शन को एक साथ दो संग्रहों पर लागू करता है। संग्रह में समान आकार होना चाहिए।
iteri: (int → 'T → unit) →' T सूची → इकाई संग्रह के प्रत्येक तत्व के लिए दिए गए फ़ंक्शन को लागू करता है। फ़ंक्शन को दिया गया पूर्णांक तत्व के सूचकांक को इंगित करता है।
iteri2: (int → 'T1 →' T2 → इकाई) → 'T1 सूची →' T2 सूची → इकाई दिए गए फ़ंक्शन को एक साथ दो संग्रहों पर लागू करता है। संग्रह में समान आकार होना चाहिए। फ़ंक्शन को दिया गया पूर्णांक तत्व के सूचकांक को इंगित करता है।
लंबाई: 'टी सूची → इंट सूची की लंबाई लौटाता है।
नक्शा: ('T →' U) → 'T सूची →' U सूची एक नया संग्रह बनाता है जिसके तत्व संग्रह के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणाम हैं।
map2: ('T1 →' T2 → 'U) →' T1 सूची → 'T2 सूची →' U सूची एक नया संग्रह बनाता है जिसके तत्व दिए गए फ़ंक्शन को दो संग्रह जोड़ी के संगत तत्वों पर लागू करने के परिणाम हैं।
map3: ('T1 →' T2 → 'T3 →' U) → 'T1 सूची →' T2 सूची → 'T3 सूची →' U सूची एक नया संग्रह बनाता है जिसके तत्व दिए गए फ़ंक्शन को तीन संग्रह के संबंधित तत्वों पर एक साथ लागू करने के परिणाम हैं।
मेपी: (int → 'T →' U) → 'T सूची →' U सूची एक नया संग्रह बनाता है जिसके तत्व संग्रह के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणाम हैं। फ़ंक्शन के लिए दिया गया पूर्णांक सूचकांक तत्व के इंडेक्स (0 से) को इंगित करता है जो रूपांतरित हो रहा है।
mapi2: (int → 'T1 →' T2 → 'U) →' T1 सूची → 'T2 सूची →' अंतिम सूची List.mapi की तरह, लेकिन समान लंबाई की दो सूचियों से संबंधित तत्वों की मैपिंग करें।
अधिकतम: 'टी सूची →' टी ऑपरेटर्समैक्स का उपयोग करके तुलना में सूची के सभी तत्वों में से सबसे बड़ा रिटर्न।
maxBy: ('T →' U) → 'T सूची →' T फ़ंक्शन परिणाम पर ऑपरेटर्समैक्स का उपयोग करके, सूची के सभी तत्वों में से सबसे बड़ा रिटर्न देता है।
न्यूनतम: 'टी सूची →' टी ऑपरेटर्स.मिन की तुलना में सूची के सभी तत्वों में से सबसे कम रिटर्न देता है।
minBy: ('T →' U) → 'T सूची →' T फ़ंक्शन परिणाम पर Operators.min का उपयोग करके, सूची के सभी तत्वों के निम्नतम को लौटाता है
nth: 'T सूची → int →' T सूची में शामिल करता है। पहले तत्व में इंडेक्स 0 है।
AArray: 'T [] →' T सूची दी गई सरणी से एक सूची बनाता है।
.Seq: seq <'T> →' T सूची दी गई गणना योग्य वस्तु से एक नई सूची बनाता है।
विभाजन: ('टी → बूल) →' टी सूची * 'टी सूची संग्रह को दो संग्रहों में विभाजित करता है, जिसमें वे तत्व होते हैं जिनके लिए दिए गए विधेय रिटर्न देते हैं true तथा false क्रमशः।
परमिट: (int → int) → 'टी सूची →' टी सूची निर्दिष्ट अनुमति के अनुसार अनुमत सभी तत्वों के साथ एक सूची देता है।
पिक: ('टी →' यू विकल्प) → 'टी सूची →' यू दिए गए फ़ंक्शन को क्रमिक तत्वों पर लागू करता है, पहला परिणाम देता है जहां फ़ंक्शन रिटर्न करता है Some कुछ मूल्य के लिए।
कम करें: ('T →' T → 'T) →' T सूची → 'T संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाता है। यह फ़ंक्शन सूची के पहले दो तत्वों के लिए निर्दिष्ट फ़ंक्शन को लागू करता है। यह तब तीसरे तत्व के साथ फ़ंक्शन में इस परिणाम को पारित करता है, और इसी तरह। अंत में, यह अंतिम परिणाम देता है। यदि इनपुट फ़ंक्शन f है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (f i0 i1) i2 ...) iN गणना करता है।
कम करें: ('T →' T → 'T) →' T सूची → 'T संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाता है। यदि इनपुट फ़ंक्शन isf और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f i0 (... (f iN-1 iN)) की गणना करता है।
प्रतिकृति: (int → 'T →' T सूची) प्रत्येक इंडेक्स पर दिए गए जनरेटर को कॉल करके एक सूची बनाता है।
Rev: 'T सूची →' T सूची रिवर्स ऑर्डर में तत्वों के साथ एक नई सूची देता है।
स्कैन: ('राज्य →' टी → 'राज्य) →' राज्य → 'टी सूची →' राज्य सूची संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाता है। यह फ़ंक्शन दूसरा तर्क लेता है, और इसे निर्दिष्ट फ़ंक्शन और सूची के पहले तत्व को लागू करता है। फिर, यह इस परिणाम को दूसरे तत्व और इसी के साथ फ़ंक्शन में पास करता है। अंत में, यह मध्यवर्ती परिणाम और अंतिम परिणाम की सूची लौटाता है।
स्कैनबैक: ('टी →' राज्य → 'राज्य) →' टी सूची → 'राज्य →' राज्य सूची फोल्डबैक की तरह, लेकिन मध्यवर्ती और अंतिम परिणाम दोनों लौटाता है
सॉर्ट: 'टी सूची →' टी सूची ऑपरेटर्स.कॉम का उपयोग करके दी गई सूची को सॉर्ट करता है।
SortBy: ('T →' की) → 'T सूची →' T सूची दिए गए प्रक्षेपण द्वारा दी गई कुंजियों का उपयोग करके दी गई सूची को सॉर्ट करता है। ऑपरेटर्स.कॉम की मदद से कीज़ की तुलना की जाती है।
SortWith: ('T →' T → int) → 'T सूची →' T सूची दिए गए तुलना फ़ंक्शन का उपयोग करके दी गई सूची को सॉर्ट करता है।
योग: ^ टी सूची → ^ टी सूची में तत्वों का योग लौटाता है।
sumBy: ('T → ^ U) →' T सूची → ^ U सूची के प्रत्येक तत्व में फ़ंक्शन को लागू करके उत्पन्न परिणामों का योग लौटाता है।
पूंछ: 'टी सूची →' टी सूची पहले तत्व के बिना इनपुट सूची देता है।
ऐरे: 'टी सूची →' टी [] दी गई सूची से एक सरणी बनाता है।
toSeq: 'T सूची → seq <' T> अनुक्रम के रूप में दी गई सूची को देखें।
tryFind: ('T → बूल) →' T सूची → 'T विकल्प पहला तत्व लौटाता है जिसके लिए दिए गए फ़ंक्शन देता है true। वापसीNone यदि ऐसा कोई तत्व मौजूद नहीं है।
tryFindIndex: ('T → बूल) →' T सूची → int विकल्प सूची में पहले तत्व के सूचकांक को लौटाता है जो दिए गए विधेय को संतुष्ट करता है। वापसीNone यदि ऐसा कोई तत्व मौजूद नहीं है।
tryPick: ('T →' U विकल्प) → 'T सूची →' U विकल्प दिए गए फ़ंक्शन को क्रमिक तत्वों पर लागू करता है, पहला परिणाम देता है जहां फ़ंक्शन रिटर्न करता है Someकुछ मूल्य के लिए। यदि ऐसा कोई तत्व मौजूद नहीं है, तो वापस लौटेंNone
unzip: ('T1 *' T2) सूची → 'T1 सूची *' T2 सूची दो सूचियों में जोड़े की एक सूची को विभाजित करता है।
unzip3: ('T1 *' T2 * 'T3) सूची →' T1 सूची * 'T2 सूची * T3 सूची तीन सूची में तीनों की सूची को विभाजित करता है।
zip: 'T1 सूची →' T2 सूची → ('T1 *' T2) सूची दो सूचियों को जोड़ियों की सूची में मिलाता है। दो सूचियों की लंबाई समान होनी चाहिए।
zip3: 'T1 सूची →' T2 सूची → 'T3 सूची → (' T1 * 'T2 *' सूची '3) तीन सूचियों को त्रिगुणों की सूची में मिलाता है। सूचियों की लंबाई समान होनी चाहिए।

निम्नलिखित उदाहरण उपरोक्त क्रियाओं के उपयोग को प्रदर्शित करते हैं -

उदाहरण 1

यह कार्यक्रम एक सूची को पुनरावर्ती रूप से दिखाता है -

let list1 = [ 2; 4; 6; 8; 10; 12; 14; 16 ]
printfn "The original list: %A" list1

let reverse lt =
   let rec loop acc = function
      | [] -> acc
      | hd :: tl -> loop (hd :: acc) tl
   loop [] lt

printfn "The reversed list: %A" (reverse list1)

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

The original list: [2; 4; 6; 8; 10; 12; 14; 16]
The reversed list: [16; 14; 12; 10; 8; 6; 4; 2]

हालाँकि, आप इसका उपयोग कर सकते हैं rev इसी उद्देश्य के लिए मॉड्यूल का कार्य -

let list1 = [ 2; 4; 6; 8; 10; 12; 14; 16 ]
printfn "The original list: %A" list1
printfn "The reversed list: %A" (List.rev list1)

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

The original list: [2; 4; 6; 8; 10; 12; 14; 16]
The reversed list: [16; 14; 12; 10; 8; 6; 4; 2]

उदाहरण 2

यह प्रोग्राम सूची का उपयोग करके सूची को फ़िल्टर करने को दर्शाता है List.filter विधि -

let list1 = [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
printfn "The list: %A" list1
let list2 = list1 |> List.filter (fun x -> x % 2 = 0);;
printfn "The Filtered list: %A" list2

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

The list: [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
The Filtered list: [2; 4; 6; 8; 10]

उदाहरण 3

List.map विधि सूची को एक प्रकार से दूसरे प्रकार में मैप करती है -

let list1 = [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
printfn "The list: %A" list1
let list2 = list1 |> List.map (fun x -> (x * x).ToString());;
printfn "The Mapped list: %A" list2

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

The list: [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
The Mapped list: ["1"; "4"; "9"; "16"; "25"; "36"; "49"; "64"; "81"; "100"]

उदाहरण 4

List.append विधि और @ ऑपरेटर एक सूची को दूसरे में जोड़ता है -

let list1 = [1; 2; 3; 4; 5 ]
let list2 = [6; 7; 8; 9; 10]
let list3 = List.append list1 list2

printfn "The first list: %A" list1
printfn "The second list: %A" list2
printfn "The appened list: %A" list3

let lt1 = ['a'; 'b';'c' ]
let lt2 = ['e'; 'f';'g' ]
let lt3 = lt1 @ lt2

printfn "The first list: %A" lt1
printfn "The second list: %A" lt2
printfn "The appened list: %A" lt3

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

The first list: [1; 2; 3; 4; 5]
The second list: [6; 7; 8; 9; 10]
The appened list: [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]
The first list: ['a'; 'b'; 'c']
The second list: ['e'; 'f'; 'g']
The appened list: ['a'; 'b'; 'c'; 'e'; 'f'; 'g']

उदाहरण 5

List.sortविधि एक सूची बनाती है। List.sum विधि सूची में तत्वों का योग देती है और List.average विधि सूची में तत्वों का औसत देती है -

let list1 = [9.0; 0.0; 2.0; -4.5; 11.2; 8.0; -10.0]
printfn "The list: %A" list1

let list2 = List.sort list1
printfn "The sorted list: %A" list2

let s = List.sum list1
let avg = List.average list1
printfn "The sum: %f" s
printfn "The average: %f" avg

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

The list: [9.0; 0.0; 2.0; -4.5; 11.2; 8.0; -10.0]
The sorted list: [-10.0; -4.5; 0.0; 2.0; 8.0; 9.0; 11.2]
The sum: 15.700000
The average: 2.242857

एक "गुना" ऑपरेशन एक सूची में प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, फ़ंक्शन के परिणाम को एक संचयकर्ता चर में एकत्र करता है, और संचयकर्ता को गुना ऑपरेशन के परिणामस्वरूप वापस करता है।

उदाहरण 6

List.fold विधि प्रत्येक तत्व को बाएं से दाएं, जबकि तक एक फ़ंक्शन लागू करती है List.foldBack प्रत्येक तत्व को दाईं से बाईं ओर एक फ़ंक्शन लागू करता है।

let sumList list = List.fold (fun acc elem -> acc + elem) 0 list
printfn "Sum of the elements of list %A is %d." [ 1 .. 10 ] (sumList [ 1 .. 10 ])

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

Sum of the elements of list [1; 2; 3; 4; 5; 6; 7; 8; 9; 10] is 55.

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

अनुक्रमों को परिभाषित करना

निम्नलिखित सिंटैक्स का उपयोग करके दृश्यों को परिभाषित किया जाता है -

seq { expr }

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

let seq1 = seq { 1 .. 10 }

अनुक्रम और अनुक्रम अभिव्यक्तियाँ बनाना

सूचियों के समान, आप श्रेणियों और समझ का उपयोग करके अनुक्रम बना सकते हैं।

अनुक्रम अभिव्यक्तियाँ हैं जो आप अनुक्रम बनाने के लिए लिख सकते हैं। ये किए जा सकते हैं -

  • सीमा निर्दिष्ट करके।
  • श्रेणी में वृद्धि या वृद्धि के साथ निर्दिष्ट करके।
  • का उपयोग करके yield मूल्यों का निर्माण करने के लिए कीवर्ड जो अनुक्रम का हिस्सा बन जाता है।
  • → ऑपरेटर का उपयोग करके।

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

उदाहरण 1

(* Sequences *)
let seq1 = seq { 1 .. 10 }

(* ascending order and increment*)
printfn "The Sequence: %A" seq1
let seq2 = seq { 1 .. 5 .. 50 }

(* descending order and decrement*)
printfn "The Sequence: %A" seq2
let seq3 = seq {50 .. -5 .. 0}
printfn "The Sequence: %A" seq3

(* using yield *)
let seq4 = seq { for a in 1 .. 10 do yield a, a*a, a*a*a }
printfn "The Sequence: %A" seq4

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

The Sequence: seq [1; 2; 3; 4; ...]
The Sequence: seq [1; 6; 11; 16; ...]
The Sequence: seq [50; 45; 40; 35; ...]
The Sequence: seq [(1, 1, 1); (2, 4, 8); (3, 9, 27); (4, 16, 64); ...]

उदाहरण 2

निम्नलिखित कार्यक्रम 1 से 50 तक की प्रमुख संख्या छापता है -

(* Recursive isprime function. *)
let isprime n =
   let rec check i =
      i > n/2 || (n % i <> 0 && check (i + 1))
   check 2

let primeIn50 = seq { for n in 1..50 do if isprime n then yield n }
for x in primeIn50 do
   printfn "%d" x

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

1
2
3
5
7
11
13
17
19
23
29
31
37
41
43
47

अनुक्रम पर बुनियादी संचालन

निम्न तालिका अनुक्रम डेटा प्रकार पर मूल संचालन को दर्शाती है -

मूल्य विवरण
append: seq <'T> → seq <' T> → seq <'T> दिए गए दो समागमों को एक समसामयिक अभिगम के रूप में लपेटता है।
औसत: seq <^ T> → ^ T अनुक्रम में तत्वों का औसत लौटाता है।
औसतन: ('T → ^ U) → seq <' T> → ^ U अनुक्रम के प्रत्येक तत्व में फ़ंक्शन को लागू करके उत्पन्न परिणामों का औसत लौटाता है।
कैश: seq <'T> → seq <' T> एक अनुक्रम देता है जो इनपुट अनुक्रम के कैश्ड संस्करण से मेल खाता है।
कास्ट: IEnumerable → seq <'T> एक शिथिल टाइप प्रणाली को लपेटता है। संग्रह एक अनुक्रम के रूप में अनुक्रम।
चुनें: ('T →' U विकल्प) → seq <'T> → seq <' U> दिए गए फ़ंक्शन को सूची के प्रत्येक तत्व पर लागू करता है। प्रत्येक तत्व के लिए परिणामों में शामिल सूची लौटाएँ जहाँ फ़ंक्शन लौटता हैSome
एकत्र: ('T →' संग्रह) → seq <'T> → seq <' U> दिए गए फ़ंक्शन को अनुक्रम के प्रत्येक तत्व पर लागू करता है और सभी परिणामों को संक्षिप्त करता है।
तुलना करें: ('T →' T → int) → seq <'T> → seq <' T> → int दिए गए तुलनात्मक फ़ंक्शन, तत्व द्वारा तत्व का उपयोग करके दो अनुक्रमों की तुलना करता है।
concat: seq <'Collection> → seq <' T> दिए गए एन्यूमरेशन-ऑफ-एन्यूमरेशन्स को सिंगल कॉन्टेनेटेड एन्यूमरेशन के रूप में जोड़ती है।
countBy: ('T →' की) → seq <'T> → seq <' Key * int> एक अनुक्रम के प्रत्येक तत्व के लिए एक कुंजी-उत्पादक फ़ंक्शन को लागू करता है और एक अनुक्रम देता है जो अद्वितीय अनुक्रम और मूल अनुक्रम में होने वाली घटनाओं की संख्या देता है।
देरी: (इकाई → seq <'T>) → seq <' T> एक अनुक्रम देता है जो किसी अनुक्रम के दिए गए विलंबित विनिर्देश से निर्मित होता है।
अलग: seq <'T> → seq <' T> एक अनुक्रम देता है जिसमें सामान्य हैश और प्रविष्टियों पर समानता की तुलना के अनुसार कोई डुप्लिकेट प्रविष्टियाँ नहीं होती हैं। यदि कोई तत्व अनुक्रम में कई बार होता है तो बाद की घटनाओं को छोड़ दिया जाता है।
विशिष्ट: ('टी →' कुंजी) → seq <'T> → seq <' T> एक अनुक्रम देता है जिसमें दिए गए कुंजी-जनरेटिंग फ़ंक्शन द्वारा लौटाए गए कुंजी पर सामान्य हैश और समानता की तुलना के अनुसार कोई डुप्लिकेट प्रविष्टियां नहीं हैं। यदि कोई तत्व अनुक्रम में कई बार होता है तो बाद की घटनाओं को छोड़ दिया जाता है।
खाली: seq <'T> एक खाली क्रम बनाता है।
बिल्कुल: seq <'T> →' T अनुक्रम का एकमात्र तत्व देता है।
मौजूद है: ('T → बूल) → seq <' T> → बूल यदि अनुक्रम का कोई तत्व दिए गए विधेय को संतुष्ट करता है तो परीक्षण।
मौजूद 2: ('T1 →' T2 → बूल) → seq <'T1> → seq <' T2 → → बूल टेस्ट अगर इनपुट अनुक्रमों के संबंधित तत्वों की किसी भी जोड़ी को दिए गए विधेय को संतुष्ट करता है।
फ़िल्टर: ('T → बूल) → seq <' T> → seq <'T> एक नया संग्रह लौटाता है जिसमें संग्रह के केवल तत्व होते हैं जिसके लिए दिए गए विधेय रिटर्न देता है true
खोजें: ('T → बूल) → seq <' T> → 'T पहला तत्व लौटाता है जिसके लिए दिए गए फ़ंक्शन देता है true
findIndex: ('T → बूल) → seq <' T> → int पहले तत्व के सूचकांक को लौटाता है जिसके लिए दिए गए फ़ंक्शन वापस आते हैं true
तह: ('राज्य →' टी → 'राज्य) →' राज्य → seq <'T> →' राज्य संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाता है। यदि इनपुट फ़ंक्शन f है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (fs i0) ...) iN गणना करता है।
forall: ('T → बूल) → seq <' T> → बूल यदि अनुक्रम के सभी तत्व दिए गए विधेय को संतुष्ट करते हैं तो टेस्ट करें।
forall2: ('T1 →' T2 → बूल) → seq <'T1> → seq <' T2> → बूल दो अनुक्रमों से तैयार किए गए तत्वों के सभी जोड़े टेस्ट को दिए गए विधेय को संतुष्ट करते हैं। यदि एक अनुक्रम दूसरे से छोटा है, तो लंबे अनुक्रम के शेष तत्वों को अनदेखा किया जाता है।
groupBy: ('T →' की) → seq <'T> → seq <' Key * seq <'T >> एक अनुक्रम के प्रत्येक तत्व के लिए एक कुंजी-उत्पादक फ़ंक्शन को लागू करता है और अद्वितीय कुंजियों के अनुक्रम का उत्पादन करता है। प्रत्येक अद्वितीय कुंजी में उन सभी तत्वों का क्रम भी होता है जो इस कुंजी से मेल खाते हैं।
सिर: seq <'T> →' T अनुक्रम का पहला तत्व लौटाता है।
init: int → (int → 'T) → seq <' T> एक नया अनुक्रम उत्पन्न करता है, जब iterated, दिए गए फ़ंक्शन को दिए गए गणना तक, क्रमिक तत्वों को लौटाता है। फ़ंक्शन को कॉल करने के परिणाम सहेजे नहीं जाते हैं, अर्थात, तत्वों को पुन: उत्पन्न करने के लिए फ़ंक्शन को फिर से लागू किया जाता है। फ़ंक्शन को आइटम के इंडेक्स को जनरेट किया जा रहा है।
initInfinite: (int → 'T) → seq <' T> एक नया अनुक्रम उत्पन्न करता है, जो पुनरावृत्त होने पर, दिए गए फ़ंक्शन को कॉल करके क्रमिक तत्वों को लौटाएगा। फ़ंक्शन को कॉल करने के परिणाम सहेजे नहीं जाते हैं, अर्थात, तत्वों को पुनर्जीवित करने के लिए फ़ंक्शन को फिर से लागू किया जाएगा। फ़ंक्शन को आइटम के इंडेक्स को जनरेट किया जा रहा है।
isEmpty: seq <'T> → बूल टेस्ट कि क्या किसी अनुक्रम में कोई तत्व हैं।
पुनरावृति: ('T → इकाई) → seq <' T> → इकाई संग्रह के प्रत्येक तत्व के लिए दिए गए फ़ंक्शन को लागू करता है।
iter2: ('T1 →' T2 → इकाई) → seq <'T1> → seq <' T2> → इकाई दिए गए फ़ंक्शन को एक साथ दो संग्रहों पर लागू करता है। यदि एक अनुक्रम दूसरे से छोटा है, तो लंबे अनुक्रम के शेष तत्वों को अनदेखा किया जाता है।
इतरी: (int → 'T → इकाई) → seq <' T> → इकाई संग्रह के प्रत्येक तत्व के लिए दिए गए फ़ंक्शन को लागू करता है। फ़ंक्शन को दिया गया पूर्णांक तत्व के सूचकांक को इंगित करता है।
अंतिम: seq <'T> →' T अनुक्रम का अंतिम तत्व लौटाता है।
लंबाई: seq <'T> → int अनुक्रम की लंबाई देता है।
नक्शा: ('T →' U) → seq <'T> → seq <' U> एक नया संग्रह बनाता है जिसके तत्व संग्रह के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणाम हैं। दिए गए फ़ंक्शन को लागू किया जाएगा क्योंकि तत्वों को ऑब्जेक्ट से पुनर्प्राप्त किए गए एन्यूमरेटर्स पर MoveNext विधि का उपयोग करके मांग की जाती है।
map2: ('T1 →' T2 → 'U) → seq <' T1> → seq <'T2> → seq <' U> एक नया संग्रह बनाता है जिसके तत्व दिए गए फ़ंक्शन को दो अनुक्रमों से तत्वों के संबंधित जोड़े पर लागू करने के परिणाम हैं। यदि एक इनपुट अनुक्रम दूसरे से छोटा है, तो लंबे अनुक्रम के शेष तत्वों को अनदेखा किया जाता है।
मापी: (int → 'T →' U) → seq <'T> → seq <' U> एक नया संग्रह बनाता है जिसके तत्व संग्रह के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणाम हैं। फ़ंक्शन के लिए दिया गया पूर्णांक सूचकांक तत्व के इंडेक्स (0 से) को इंगित करता है जो रूपांतरित हो रहा है।
अधिकतम: seq <'T> →' T ऑपरेटर्समैक्स का उपयोग करके तुलना में अनुक्रम के सभी तत्वों में से सबसे बड़ा रिटर्न।
maxBy: ('T →' U) → seq <'T> →' T फ़ंक्शन परिणाम पर ऑपरेटर्समैक्स का उपयोग करके तुलना में अनुक्रम के सभी तत्वों में से सबसे बड़ा रिटर्न।
मिनट: seq <'T> →' T Operators.min का उपयोग करते हुए अनुक्रम के सभी तत्वों के निम्नतम को लौटाता है।
minBy: ('T →' U) → seq <'T> →' T फ़ंक्शन परिणाम पर Operators.min का उपयोग करके अनुक्रम के सभी तत्वों के निम्नतम को लौटाता है।
nth : int → seq<'T> → 'T Computes the nth element in the collection.
ofArray : 'T array → seq<'T> Views the given array as a sequence.
ofList : 'T list → seq<'T> Views the given list as a sequence.
pairwise : seq<'T> → seq<'T * 'T> Returns a sequence of each element in the input sequence and its predecessor, with the exception of the first element which is only returned as the predecessor of the second element.
pick : ('T → 'U option) → seq<'T> → 'U Applies the given function to successive elements, returning the first value where the function returns a Some value.
readonly : seq<'T> → seq<'T> Creates a new sequence object that delegates to the given sequence object. This ensures the original sequence cannot be rediscovered and mutated by a type cast. For example, if given an array the returned sequence will return the elements of the array, but you cannot cast the returned sequence object to an array.
reduce : ('T → 'T → 'T) → seq<'T> → 'T Applies a function to each element of the sequence, threading an accumulator argument through the computation. Begin by applying the function to the first two elements. Then feed this result into the function along with the third element and so on. Return the final result.
scan : ('State → 'T → 'State) → 'State → seq<'T> → seq<'State> Like Seq.fold, but computes on-demand and returns the sequence of intermediary and final results.
singleton : 'T → seq<'T> Returns a sequence that yields one item only.
skip : int → seq<'T> → seq<'T> Returns a sequence that skips a specified number of elements of the underlying sequence and then yields the remaining elements of the sequence.
skipWhile : ('T → bool) → seq<'T> → seq<'T> Returns a sequence that, when iterated, skips elements of the underlying sequence while the given predicate returns true, and then yields the remaining elements of the sequence.
sort : seq<'T> → seq<'T> Yields a sequence ordered by keys.
sortBy : ('T → 'Key) → seq<'T> → seq<'T> Applies a key-generating function to each element of a sequence and yield a sequence ordered by keys. The keys are compared using generic comparison as implemented by Operators.compare.
sum : seq<^T> → ^T Returns the sum of the elements in the sequence.
sumBy Returns the sum of the results generated by applying the function to each element of the sequence.
take : int → seq<'T> → seq<'T> Returns the first elements of the sequence up to a specified count.
takeWhile : ('T → bool) → seq<'T> → seq<'T> Returns a sequence that, when iterated, yields elements of the underlying sequence while the given predicate returns true, and then returns no further elements.
toArray : seq<'T> → 'T[] Creates an array from the given collection.
toList : seq<'T> → 'T list Creates a list from the given collection.
truncate : int → seq<'T> → seq<'T> Returns a sequence that when enumerated returns no more than a specified number of elements.
tryFind : ('T → bool) → seq<'T> → 'T option Returns the first element for which the given function returns true, or None if no such element exists.
tryFindIndex : ('T → bool) → seq<'T> → int option Returns the index of the first element in the sequence that satisfies the given predicate, or None if no such element exists.
tryPick : ('T → 'U option) → seq<'T> → 'U option Applies the given function to successive elements, returning the first value where the function returns a Some value.
unfold : ('State → 'T * 'State option) → 'State → seq<'T> Returns a sequence that contains the elements generated by the given computation.
where : ('T → bool) → seq<'T> → seq<'T> Returns a new collection containing only the elements of the collection for which the given predicate returns true. A synonym for Seq.filter.
windowed : int → seq<'T> → seq<'T []> Returns a sequence that yields sliding windows of containing elements drawn from the input sequence. Each window is returned as a fresh array.
zip : seq<'T1> → seq<'T2> → seq<'T1 * 'T2> Combines the two sequences into a list of pairs. The two sequences need not have equal lengths − when one sequence is exhausted any remaining elements in the other sequence are ignored.
zip3 : seq<'T1> → seq<'T2> → seq<'T3> → seq<'T1 * 'T2 * 'T3> Combines the three sequences into a list of triples. The sequences need not have equal lengths − when one sequence is exhausted any remaining elements in the other sequences are ignored.

The following examples demonstrate the uses of some of the above functionalities −

Example 1

This program creates an empty sequence and fills it up later −

(* Creating sequences *)
let emptySeq = Seq.empty
let seq1 = Seq.singleton 20

printfn"The singleton sequence:"
printfn "%A " seq1
printfn"The init sequence:"

let seq2 = Seq.init 5 (fun n -> n * 3)
Seq.iter (fun i -> printf "%d " i) seq2
printfn""

(* converting an array to sequence by using cast *)
printfn"The array sequence 1:"
let seq3 = [| 1 .. 10 |] :> seq<int>
Seq.iter (fun i -> printf "%d " i) seq3
printfn""

(* converting an array to sequence by using Seq.ofArray *)
printfn"The array sequence 2:"
let seq4 = [| 2..2.. 20 |] |> Seq.ofArray
Seq.iter (fun i -> printf "%d " i) seq4
printfn""

When you compile and execute the program, it yields the following output −

The singleton sequence:
seq [20]
The init sequence:
0 3 6 9 12
The array sequence 1:
1 2 3 4 5 6 7 8 9 10
The array sequence 2:
2 4 6 8 10 12 14 16 18 20

Please note that −

  • The Seq.empty method creates an empty sequence.

  • The Seq.singleton method creates a sequence of just one specified element.

  • The Seq.init method creates a sequence for which the elements are created by using a given function.

  • The Seq.ofArray and Seq.ofList<'T> methods create sequences from arrays and lists.

  • The Seq.iter method allows iterating through a sequence.

उदाहरण 2

Seq.unfold विधि एक गणना फ़ंक्शन से एक अनुक्रम उत्पन्न करती है जो एक राज्य लेता है और अनुक्रम में प्रत्येक बाद के तत्व का उत्पादन करने के लिए इसे परिवर्तित करता है।

निम्नलिखित फ़ंक्शन पहले 20 प्राकृतिक संख्याओं का उत्पादन करता है -

let seq1 = Seq.unfold (fun state -> if (state > 20) then None else Some(state, state + 1)) 0
printfn "The sequence seq1 contains numbers from 0 to 20."
for x in seq1 do printf "%d " x
printfn" "

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

The sequence seq1 contains numbers from 0 to 20.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20

उदाहरण 3

Seq.truncate विधि किसी अन्य अनुक्रम से अनुक्रम बनाती है, लेकिन अनुक्रम को तत्वों की एक निर्दिष्ट संख्या तक सीमित करती है।

Seq.take विधि एक नया अनुक्रम बनाती है जिसमें अनुक्रम की शुरुआत से निर्दिष्ट तत्वों की संख्या होती है।

let mySeq = seq { for i in 1 .. 10 -> 3*i }
let truncatedSeq = Seq.truncate 5 mySeq
let takeSeq = Seq.take 5 mySeq

printfn"The original sequence"
Seq.iter (fun i -> printf "%d " i) mySeq
printfn""

printfn"The truncated sequence"
Seq.iter (fun i -> printf "%d " i) truncatedSeq
printfn""

printfn"The take sequence"
Seq.iter (fun i -> printf "%d " i) takeSeq
printfn""

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

The original sequence
3 6 9 12 15 18 21 24 27 30
The truncated sequence
3 6 9 12 15
The take sequence
3 6 9 12 15

F # में एक सेट एक डेटा संरचना है जो आइटम को सम्मिलित किए गए क्रम को संरक्षित किए बिना वस्तुओं के संग्रह के रूप में कार्य करता है। सेट डुप्लिकेट प्रविष्टियों को संग्रह में सम्मिलित करने की अनुमति नहीं देते हैं।

सेट बनाना

सेट निम्नलिखित तरीकों से बनाए जा सकते हैं -

  • सेट फ़ंक्शन का उपयोग करके Set.empty और आइटम जोड़कर एक खाली सेट बनाकर।
  • सेट करने के लिए दृश्यों और सूचियों को परिवर्तित करना।

निम्नलिखित कार्यक्रम तकनीकों को प्रदर्शित करता है -

(* creating sets *)
let set1 = Set.empty.Add(3).Add(5).Add(7). Add(9)
printfn"The new set: %A" set1

let weekdays = Set.ofList ["mon"; "tues"; "wed"; "thurs"; "fri"]
printfn "The list set: %A" weekdays

let set2 = Set.ofSeq [ 1 .. 2.. 10 ]
printfn "The sequence set: %A" set2

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

The new set: set [3; 5; 7; 9]
The list set: set ["fri"; "mon"; "thurs"; "tues"; "wed"]
The sequence set: set [1; 3; 5; 7; 9]

सेट पर बुनियादी संचालन

निम्न तालिका सेट पर मूल संचालन को दर्शाती है -

मूल्य विवरण
जोड़ें: 'T → सेट <' T> → सेट <'T> सेट में जोड़े गए एक तत्व के साथ एक नया सेट लौटाता है। कोई अपवाद नहीं उठाया जाता है यदि सेट में पहले से ही दिए गए तत्व हैं।
इसमें शामिल हैं: 'T → सेट <' T> → बूल का मूल्यांकन करता है true यदि दिए गए तत्व दिए गए सेट में हैं।
गणना: सेट <'T> → int सेट में तत्वों की संख्या लौटाता है।
अंतर: सेट <'T> → सेट <' T> → सेट <'T> पहले से हटाए गए दूसरे सेट के तत्वों के साथ एक नया सेट लौटाता है।
खाली: सेट <'T> निर्दिष्ट प्रकार के लिए खाली सेट।
मौजूद है: ('टी → बूल) → सेट <' टी> → बूल टेस्ट अगर संग्रह का कोई तत्व दिए गए विधेय को संतुष्ट करता है। यदि इनपुट फ़ंक्शन विधेय है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन i0 या ... या iN की भविष्यवाणी करता है।
फ़िल्टर: ('T → बूल) → सेट <' T> → सेट <'T> एक नया संग्रह लौटाता है जिसमें संग्रह के केवल तत्व होते हैं जिसके लिए दिए गए विधेय रिटर्न देता है true
तह: ('राज्य →' टी → 'राज्य) →' राज्य → सेट <'टी> →' राज्य सेट के सभी तत्वों को दिए गए संचय समारोह को लागू करता है।
foldBack: ('T →' State → 'State) → सेट <' T> → 'State →' State सेट के सभी तत्वों को दिए गए संचय समारोह को लागू करता है।
forall: ('टी → बूल) → सेट <' टी> → बूल टेस्ट अगर संग्रह के सभी तत्व दिए गए विधेय को संतुष्ट करते हैं। यदि इनपुट फ़ंक्शन p है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन p i0 && ... && p iN की गणना करता है।
इंटरसेक्ट: सेट <'T> → सेट <' T> → सेट <'T> दो सेटों के प्रतिच्छेदन की गणना करता है।
इंटरसेक्टमनी: seq <सेट <'T >> → सेट <' T> सेट के एक अनुक्रम के प्रतिच्छेदन की गणना करता है। अनुक्रम गैर-रिक्त होना चाहिए।
isEmpty: सेट <'T> → बूल रिटर्न true अगर सेट खाली है।
isProperSubset: सेट <'T> → सेट <' T> → बूल का मूल्यांकन करता है true यदि पहले सेट के सभी तत्व दूसरे में हैं, और दूसरे का कम से कम एक तत्व पहले में नहीं है।
isProperSuperset: सेट करें <'T> → सेट <' T> → बूल का मूल्यांकन करता है true यदि दूसरे सेट के सभी तत्व पहले में हैं, और पहले का कम से कम एक तत्व दूसरे में नहीं है।
isSubset: सेट <'T> → सेट <' T> → बूल का मूल्यांकन करता है true यदि पहले सेट के सभी तत्व दूसरे में हैं।
isSuperset: सेट <'T> → सेट <' T> → बूल का मूल्यांकन करता है true यदि दूसरे सेट के सभी तत्व पहले में हैं।
पुनरावृति: ('T → इकाई) → सेट <' T> → इकाई तुलना फ़ंक्शन के अनुसार सेट के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करता है।
नक्शा: ('T →' U) → सेट <'T> → सेट <' U> इनपुट सेट के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणामों से युक्त एक नया संग्रह लौटाता है।
maxElement: सेट करें <'T> →' T सेट के लिए उपयोग किए जा रहे ऑर्डर के अनुसार सेट में उच्चतम तत्व देता है।
minElement: सेट करें <'T> →' T सेट के लिए उपयोग किए जा रहे ऑर्डर के अनुसार सेट में सबसे कम तत्व देता है।
सरणी: 'T सरणी → सेट <' T> एक सेट बनाता है जिसमें दिए गए सरणी के समान तत्व होते हैं।
सूची: 'टी सूची → सेट <' टी> एक सेट बनाता है जिसमें दिए गए सूची के समान तत्व होते हैं।
ofSeq: seq <'T> → सेट <' T> दी गई असंख्य वस्तु से एक नया संग्रह बनाता है।
विभाजन: ('टी → बूल) → सेट <' टी> → सेट <'टी> * सेट <' टी> दो सेटों में सेट को विभाजित करता है जिसमें ऐसे तत्व होते हैं जिनके लिए दिए गए विधेय क्रमशः सही और झूठे होते हैं।
निकालें: 'T → सेट <' T> → सेट <'T> दिए गए तत्व के साथ एक नया सेट लौटाता है। यदि सेट दिए गए तत्व में नहीं है तो कोई अपवाद नहीं उठाया गया है।
सिंगलटन: 'टी → सेट <' टी> दिए गए तत्व से युक्त सेट।
सरणी: सेट <'T> →' T सरणी एक सरणी बनाता है जिसमें सेट के तत्व शामिल होते हैं।
सूची: <<T> → 'टी सूची सेट करें एक सूची बनाता है जिसमें सेट के तत्व शामिल होते हैं।
.Seq: सेट <'T> → seq <' T> संग्रह का आदेश दिया गया दृश्य एक देखने योग्य वस्तु के रूप में देता है।
संघ: सेट <'T> → सेट <' T> → सेट <'T> दो सेटों के मिलन की गणना करता है।
UnionMany: seq <Set <'T >> → सेट <' T> सेट के अनुक्रम के संघ की गणना करता है।

निम्नलिखित उदाहरण उपर्युक्त कुछ कार्यात्मकताओं के उपयोग को प्रदर्शित करता है -

उदाहरण

let a = Set.ofSeq [ 1 ..2.. 20 ]
let b = Set.ofSeq [ 1 ..3 .. 20 ]
let c = Set.intersect a b
let d = Set.union a b
let e = Set.difference a b

printfn "Set a: "
Set.iter (fun x -> printf "%O " x) a
printfn""

printfn "Set b: "
Set.iter (fun x -> printf "%O " x) b
printfn""

printfn "Set c = set intersect of a and b : "
Set.iter (fun x -> printf "%O " x) c
printfn""

printfn "Set d = set union of a and b : "
Set.iter (fun x -> printf "%O " x) d
printfn""

printfn "Set e = set difference of a and b : "
Set.iter (fun x -> printf "%O " x) e
printfn""

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

Set a:
1 3 5 7 9 11 13 15 17 19
Set b:
1 4 7 10 13 16 19
Set c = set intersect of a and b :
1 7 13 19
Set d = set union of a and b :
1 3 4 5 7 9 10 11 13 15 16 17 19
Set e = set difference of a and b :
3 5 9 11 15 17

एफ # में, एक नक्शा एक विशेष प्रकार का सेट है जो मूल्यों को कुंजी के साथ जोड़ता है। एक नक्शा उसी तरह बनाया जाता है जैसे सेट बनाए जाते हैं।

मानचित्र बनाना

Map.empty का उपयोग करके खाली नक्शा बनाकर और Add फ़ंक्शन का उपयोग करके आइटम जोड़कर मैप बनाए जाते हैं। निम्न उदाहरण यह प्रदर्शित करता है -

उदाहरण

(* Create an empty Map *)
let students =
   Map.empty. (* Creating an empty Map *)
      Add("Zara Ali", "1501").
      Add("Rishita Gupta", "1502").
      Add("Robin Sahoo", "1503").
      Add("Gillian Megan", "1504");;
printfn "Map - students: %A" students

(* Convert a list to Map *)
let capitals =
   [ "Argentina", "Buenos Aires";
      "France ", "Paris";
      "Chili", "Santiago";
      "Malaysia", " Kuala Lumpur";
      "Switzerland", "Bern" ]
   |> Map.ofList;;
printfn "Map capitals : %A" capitals

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

Map - students: map
[("Gillian Megan", "1504"); ("Rishita Gupta", "1502"); ("Robin Sahoo", "1503
");
("Zara Ali", "1501")]
Map capitals : map
[("Argentina", "Buenos Aires"); ("Chili", "Santiago"); ("France ", "Paris");
("Malaysia", " Kuala Lumpur"); ("Switzerland", "Bern")]

आप कुंजी का उपयोग करके नक्शे में व्यक्तिगत तत्वों तक पहुंच सकते हैं।

उदाहरण

(* Create an empty Map *)
let students =
   Map.empty. (* Creating an empty Map *)
      Add("Zara Ali", "1501").
      Add("Rishita Gupta", "1502").
      Add("Robin Sahoo", "1503").
      Add("Gillian Megan", "1504");;
printfn "Map - students: %A" students

(*Accessing an element using key *)
printfn "%A" students.["Zara Ali"]

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

Map - students: map
[("Gillian Megan", "1504"); ("Rishita Gupta", "1502"); ("Robin Sahoo", "1503
");
("Zara Ali", "1501")]
"1501"

मैप्स पर बुनियादी संचालन

मॉड्यूल नाम जोड़ें

निम्न तालिका नक्शे पर मूल संचालन को दर्शाती है -

सदस्य विवरण
जोड़ना दिए गए नक्शे में जोड़े गए बंधन के साथ एक नया नक्शा देता है।
ContainsKey यदि तत्व मानचित्र के डोमेन में है तो परीक्षण।
गिनती नक्शे में बाइंडिंग की संख्या।
खाली है यदि मानचित्र में कोई बाइंडिंग नहीं है, तो यह सत्य है।
मद नक्शे में एक तत्व देखो। यदि कोई बाइंडिंग मानचित्र में मौजूद नहीं है, तो KeyNotFoundException को उठाता है।
हटाना नक्शे के डोमेन से एक तत्व निकालता है। कोई अपवाद नहीं उठाया जाता है यदि तत्व मौजूद नहीं है।
TryFind नक्शे में एक तत्व देखो, एक लौटाने Some यदि तत्व मानचित्र के डोमेन में है और None अगर नहीं।

निम्नलिखित उदाहरण उपर्युक्त कुछ कार्यात्मकताओं के उपयोग को प्रदर्शित करता है -

उदाहरण

(* Create an empty Map *)
let students =
   Map.empty. (* Creating an empty Map *)
      Add("Zara Ali", "1501").
      Add("Rishita Gupta", "1502").
      Add("Robin Sahoo", "1503").
      Add("Gillian Megan", "1504").
      Add("Shraddha Dubey", "1505").
      Add("Novonil Sarker", "1506").
      Add("Joan Paul", "1507");;
printfn "Map - students: %A" students
printfn "Map - number of students: %d" students.Count

(* finding the registration number of a student*)
let found = students.TryFind "Rishita Gupta"
match found with
| Some x -> printfn "Found %s." x
| None -> printfn "Did not find the specified value."

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

Map - students: map
[("Gillian Megan", "1504"); ("Joan Paul", "1507"); ("Novonil Sarker", "1506"
);
("Rishita Gupta", "1502"); ("Robin Sahoo", "1503");
("Shraddha Dubey", "1505"); ("Zara Ali", "1501")]
Map - number of students: 7
Found 1502.

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

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

निम्न सिंटैक्स का उपयोग करके विभेदित यूनियनों को परिभाषित किया जाता है -

type type-name =
   | case-identifier1 [of [ fieldname1 : ] type1 [ * [ fieldname2 : ] 
type2 ...]
   | case-identifier2 [of [fieldname3 : ]type3 [ * [ fieldname4 : ]type4 ...]
...

हमारे की, सरल कार्यान्वयन विकल्प है, निम्नलिखित की तरह दिखाई देगा -

type choice =
   | Yes
   | No

निम्न उदाहरण प्रकार पसंद का उपयोग करता है -

type choice =
   | Yes
   | No

let x = Yes (* creates an instance of choice *)
let y = No (* creates another instance of choice *)
let main() =
   printfn "x: %A" x
   printfn "y: %A" y
main()

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

x: Yes
y: No

उदाहरण 1

निम्न उदाहरण वोल्टेज राज्यों के कार्यान्वयन को दर्शाता है जो उच्च या निम्न पर थोड़ा सेट करता है -

type VoltageState =
   | High
   | Low

let toggleSwitch = function (* pattern matching input *)
   | High -> Low
   | Low -> High

let main() =
   let on = High
   let off = Low
   let change = toggleSwitch off

   printfn "Switch on state: %A" on
   printfn "Switch off state: %A" off
   printfn "Toggle off: %A" change
   printfn "Toggle the Changed state: %A" (toggleSwitch change)

main()

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

Switch on state: High
Switch off state: Low
Toggle off: High
Toggle the Changed state: Low

उदाहरण 2

type Shape =
   // here we store the radius of a circle
   | Circle of float

   // here we store the side length.
   | Square of float

   // here we store the height and width.
   | Rectangle of float * float

let pi = 3.141592654

let area myShape =
   match myShape with
   | Circle radius -> pi * radius * radius
   | Square s -> s * s
   | Rectangle (h, w) -> h * w

let radius = 12.0
let myCircle = Circle(radius)
printfn "Area of circle with radius %g: %g" radius (area myCircle)

let side = 15.0
let mySquare = Square(side)
printfn "Area of square that has side %g: %g" side (area mySquare)

let height, width = 5.0, 8.0
let myRectangle = Rectangle(height, width)
printfn "Area of rectangle with height %g and width %g is %g" height width (area myRectangle)

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

Area of circle with radius 12: 452.389
Area of square that has side 15: 225
Area of rectangle with height 5 and width 8 is 40

F # में चर हैं immutable,जिसका मतलब है कि एक बार एक चर एक मूल्य से बंधा हुआ है, इसे बदला नहीं जा सकता है। वे वास्तव में स्थिर रीड-ओनली गुणों के रूप में संकलित हैं।

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

उदाहरण

let x = 10
let y = 20
let z = x + y

printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

let x = 15
let y = 20
let z = x + y

printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

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

Duplicate definition of value 'x'
Duplicate definition of value 'Y'
Duplicate definition of value 'Z'

उत्परिवर्तनीय चर

कई बार आपको किसी चर में संग्रहीत मानों को बदलने की आवश्यकता होती है। यह निर्दिष्ट करने के लिए कि एक कार्यक्रम के बाद के भाग में एक घोषित और असाइन किए गए चर के मूल्य में बदलाव हो सकता है, F # प्रदान करता हैmutableकीवर्ड। आप इस कीवर्ड का उपयोग करके परिवर्तनशील चर घोषित और असाइन कर सकते हैं, जिनके मूल्य आप बदल देंगे।

mutable कीवर्ड आपको एक परिवर्तनशील चर में मूल्यों को घोषित करने और असाइन करने की अनुमति देता है।

आप का उपयोग कर एक परिवर्तनशील चर के लिए कुछ प्रारंभिक मूल्य असाइन कर सकते हैं letकीवर्ड। हालांकि, इसके बाद के नए मूल्य को असाइन करने के लिए, आपको इसका उपयोग करने की आवश्यकता है<- ऑपरेटर।

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

let mutable x = 10
x <- 15

निम्नलिखित उदाहरण अवधारणा को स्पष्ट करेगा -

उदाहरण

let mutable x = 10
let y = 20
let mutable z = x + y

printfn "Original Values:"
printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

printfn "Let us change the value of x"
printfn "Value of z will change too."

x <- 15
z <- x + y

printfn "New Values:"
printfn "x: %i" x
printfn "y: %i" y
printfn "z: %i" z

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

Original Values:
x: 10
y: 20
z: 30
Let us change the value of x
Value of z will change too.
New Values:
x: 15
y: 20
z: 35

उपयोग योग्य डेटा

म्यूटेबल डेटा को अक्सर डेटा प्रोसेसिंग में उपयोग किया जाता है, विशेष रूप से रिकॉर्ड डेटा संरचना के साथ। निम्न उदाहरण यह प्रदर्शित करता है -

open System

type studentData =
   { ID : int;
      mutable IsRegistered : bool;
      mutable RegisteredText : string; }

let getStudent id =
   { ID = id;
      IsRegistered = false;
      RegisteredText = null; }

let registerStudents (students : studentData list) =
   students |> List.iter(fun st ->
      st.IsRegistered <- true
      st.RegisteredText <- sprintf "Registered %s" (DateTime.Now.ToString("hh:mm:ss"))

      Threading.Thread.Sleep(1000) (* Putting thread to sleep for 1 second to simulate processing overhead. *))

let printData (students : studentData list) =
   students |> List.iter (fun x -> printfn "%A" x)

let main() =
   let students = List.init 3 getStudent

   printfn "Before Process:"
   printData students

   printfn "After process:"
   registerStudents students
   printData students

   Console.ReadKey(true) |> ignore

main()

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

Before Process:
{ID = 0;
IsRegistered = false;
RegisteredText = null;}
{ID = 1;
IsRegistered = false;
RegisteredText = null;}
{ID = 2;
IsRegistered = false;
RegisteredText = null;}
After process:
{ID = 0;
IsRegistered = true;
RegisteredText = "Registered 05:39:15";}
{ID = 1;
IsRegistered = true;
RegisteredText = "Registered 05:39:16";}
{ID = 2;
IsRegistered = true;
RegisteredText = "Registered 05:39:17";}

Arrays निश्चित-आकार, शून्य-आधारित, निरंतर डेटा तत्वों के परस्पर संग्रह हैं जो सभी एक ही प्रकार के हैं।

ऐरे बनाना

आप विभिन्न सिंटैक्स और तरीकों का उपयोग करके या एरे मॉड्यूल से फ़ंक्शन का उपयोग करके एरेज़ बना सकते हैं। इस खंड में, हम मॉड्यूल फ़ंक्शन का उपयोग किए बिना एरे बनाने पर चर्चा करेंगे।

कार्यों के बिना सरणियों के निर्माण के तीन वाक्यात्मक तरीके हैं -

  • के बीच लगातार मूल्यों को सूचीबद्ध करके [| और |] और अर्धविराम द्वारा अलग किया गया।
  • प्रत्येक तत्व को एक अलग लाइन पर रखकर, जिस स्थिति में अर्धविराम विभाजक वैकल्पिक है।
  • अनुक्रम अभिव्यक्तियों का उपयोग करके।

आप एक बिंदु ऑपरेटर (।) और कोष्ठक ([और]) का उपयोग करके सरणी तत्वों तक पहुँच सकते हैं।

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

//using semicolon separator
let array1 = [| 1; 2; 3; 4; 5; 6 |]
for i in 0 .. array1.Length - 1 do
   printf "%d " array1.[i]
printfn" "

// without semicolon separator
let array2 =
   [|
      1
      2
      3
      4
      5
   |]
for i in 0 .. array2.Length - 1 do
   printf "%d " array2.[i]
printfn" "

//using sequence
let array3 = [| for i in 1 .. 10 -> i * i |]
for i in 0 .. array3.Length - 1 do
   printf "%d " array3.[i]
printfn" "

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

1 2 3 4 5 6
1 2 3 4 5
1 4 9 16 25 36 49 64 81 100

बुनियादी संचालन

लाइब्रेरी मॉड्यूल Microsoft.FSharp.Collections.Array एक आयामी सरणियों पर संचालन का समर्थन करता है।

निम्न तालिका Arrays पर मूल संचालन को दर्शाती है -

मूल्य विवरण
परिशिष्ट: 'टी [] →' टी [] → 'टी [] एक सरणी बनाता है जिसमें एक सरणी के तत्व होते हैं और उसके बाद दूसरे सरणी के तत्व होते हैं।
औसत: ^ टी [] → ^ टी किसी सरणी में तत्वों का औसत लौटाता है।
औसतन: ('T → ^ U) →' T [] → ^ U किसी सरणी के प्रत्येक तत्व में फ़ंक्शन को लागू करके उत्पन्न तत्वों का औसत लौटाता है।
blit: 'T [] → int →' T [] → int → int → इकाई एक सरणी से कई तत्वों को पढ़ता है और उन्हें दूसरे में लिखता है।
चुनें: ('T → U विकल्प) →' T [] → 'U [] किसी सरणी के प्रत्येक तत्व के लिए एक दिया गया फ़ंक्शन लागू करता है। एक एरे को लौटाता है जिसमें प्रत्येक तत्व के लिए परिणाम x होता है जिसके लिए फ़ंक्शन कुछ (x) देता है।
एकत्र: ('T →' U []) → T [] → 'U [] किसी सरणी के प्रत्येक तत्व के लिए दिए गए फ़ंक्शन को लागू करता है, परिणामों को संक्षिप्त करता है, और संयुक्त सरणी देता है।
कॉन्कैट: seq <'T []> →' T [] एक सरणी बनाता है जिसमें सरणियों के प्रत्येक दिए गए अनुक्रम के तत्व शामिल हैं।
कॉपी: 'टी →' टी [] एक सरणी बनाता है जिसमें आपूर्ति किए गए सरणी के तत्व होते हैं।
बनाएँ: int → 'T →' T [] एक ऐसा ऐरे बनाता है जिसके सभी तत्व शुरू में आपूर्ति मूल्य हैं।
खाली: 'टी [] दिए गए प्रकार की एक खाली सरणी देता है।
मौजूद है: ('टी → बूल) →' टी [] → बूल परीक्षण कि क्या किसी सरणी का कोई तत्व प्रदत्त विधेय को संतुष्ट करता है।
मौजूद 2: ('T1 →' T2 → बूल) → 'T1 [] →' T2 [] → बूल टेस्ट कि क्या दो सरणियों के संगत तत्वों की कोई भी जोड़ी आपूर्ति की स्थिति को संतुष्ट करती है।
भरें: 'T [] → int → int →' T → इकाई आपूर्ति की गई मान के साथ किसी सरणी के तत्वों की एक श्रृंखला को भरता है।
फ़िल्टर: ('टी → बूल) →' टी [] → 'टी [] एक संग्रह लौटाता है जिसमें केवल दिए गए सरणी के तत्व होते हैं जिसके लिए आपूर्ति की गई स्थिति वापस आती है true
खोजें: ('टी → बूल) →' टी [] → 'टी पहला तत्व लौटाता है जिसके लिए आपूर्ति की गई फ़ंक्शन देता है true। यदि ऐसा कोई तत्व मौजूद नहीं है, तो KeyNotFoundException उठाती है।
findIndex: ('टी → बूल) →' टी [] → इंट एक सरणी में पहले तत्व के सूचकांक को लौटाता है जो आपूर्ति की स्थिति को संतुष्ट करता है। यदि तत्व में से कोई भी स्थिति को संतुष्ट नहीं करता है, तो KeyNotFoundException को उठाता है।
तह: ('राज्य →' टी → 'राज्य) →' राज्य → 'टी [] →' राज्य एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और सरणी तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (fs i0) ...) iN की गणना करता है।
fold2: ('राज्य →' T1 → 'T2 →' राज्य) → 'राज्य →' T1 [] → 'T2 [] →' राज्य दो आपूर्ति किए गए सरणियों से तत्वों के जोड़े पर एक फ़ंक्शन लागू होता है, बाएं-से-दाएं, संगणना के माध्यम से एक संचायक तर्क को फैलाना। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
foldBack: ('T →' State → 'State) →' T [] → 'State →' स्टेट एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और सरणी तत्व i0 ... iN हैं, तो यह फ़ंक्शन f i0 (... (f iN s)) की गणना करता है।
foldBack2: ('T1 →' T2 → 'राज्य →' राज्य) → 'T1 [] →' T2 [] → 'राज्य →' राज्य दो आपूर्ति किए गए सरणियों से तत्वों के जोड़े पर एक फ़ंक्शन लागू करता है, दाएं-से-बाएं, संगणना के माध्यम से एक संचायक तर्क को फैलाता है। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
forall: ('टी → बूल) →' टी [] → बूल टेस्ट कि क्या सरणी के सभी तत्व आपूर्ति की स्थिति को संतुष्ट करते हैं।
forall2: ('T1 →' T2 → बूल) → 'T1 [] →' T2 [] → बूल टेस्ट कि क्या दो आपूर्ति की सरणियों के सभी संबंधित तत्व एक आपूर्ति की स्थिति को संतुष्ट करते हैं।
प्राप्त करें: 'T [] → int →' T एक सरणी से एक तत्व हो जाता है।
init: int → (int → 'T) →' T [] आपूर्ति की गई आयाम की एक सरणी बनाने के लिए एक आपूर्ति फ़ंक्शन का उपयोग करता है।
isEmpty: 'T [] → बूल परीक्षण कि क्या किसी सरणी में कोई तत्व हैं।
पुनरावृति: ('T → इकाई) →' T [] → इकाई किसी सरणी के प्रत्येक तत्व को दिया गया फ़ंक्शन लागू करता है।
iter2: ('T1 →' T2 → इकाई) → 'T1 [] →' T2 [] → इकाई) दो सरणियों में मिलान अनुक्रमित से तत्वों की एक जोड़ी के लिए आपूर्ति की गई फ़ंक्शन को लागू करता है। दो सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
इतरी: (int → 'T → इकाई) →' T [] → इकाई किसी सरणी के प्रत्येक तत्व को दिया गया फ़ंक्शन लागू करता है। फ़ंक्शन को दिया गया पूर्णांक तत्व के सूचकांक को इंगित करता है।
iteri2: (int → 'T1 →' T2 → इकाई) → 'T1 [] →' T2 [] → इकाई दो सरणियों में मिलान अनुक्रमित से तत्वों की एक जोड़ी के लिए आपूर्ति की गई फ़ंक्शन को लागू करता है, तत्वों के सूचकांक को भी पारित करता है। दो सरणियों की लंबाई समान होनी चाहिए; अन्यथा, एक ArgumentException उठाई जाती है।
लंबाई: 'टी [] → इंट किसी सरणी की लंबाई देता है। लंबाई संपत्ति एक ही काम करती है।
नक्शा: ('T →' U) → 'T [] →' U [] एक सरणी बनाता है जिसके तत्व आपूर्ति किए गए सरणी के प्रत्येक तत्व के लिए आपूर्ति किए गए फ़ंक्शन को लागू करने के परिणाम हैं।
map2: ('T1 →' T2 → 'U) →' T1 [] → 'T2 [] →' U] एक एरे बनाता है जिसके तत्व सप्लाई किए गए फ़ंक्शन को दो सप्लाई किए गए एरेज़ के संबंधित तत्वों पर लागू करने के परिणाम हैं। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
मेपी: (int → 'T →' U) → 'T [] →' U [] एक सरणी बनाता है जिसके तत्व आपूर्ति किए गए सरणी के प्रत्येक तत्व के लिए आपूर्ति किए गए फ़ंक्शन को लागू करने के परिणाम हैं। फ़ंक्शन के लिए दिया गया एक पूर्णांक सूचकांक तत्व के सूचकांक को रूपांतरित होने का संकेत देता है।
mapi2: (int → 'T1 →' T2 → 'U) →' T1 [] → 'T2 [] →' U [] एक ऐसा ऐरे बनाता है जिसके तत्व युग्म के दो तत्वों के संगत तत्वों के लिए आपूर्ति किए गए फ़ंक्शन को लागू करने के परिणाम होते हैं, तत्वों के सूचकांक को भी पास करते हैं। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
अधिकतम: 'टी [] →' टी किसी सरणी के सभी तत्वों में से सबसे बड़ा देता है। Operators.max का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
maxBy: ('T →' U) → 'T [] →' T फ़ंक्शन परिणाम पर Operators.max के माध्यम से तुलना करके किसी सरणी के सभी तत्वों का सबसे बड़ा रिटर्न देता है।
मिनट: ('टी [] →' टी) किसी सरणी के सभी तत्वों में से सबसे छोटा लौटाता है। Operators.min का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
minBy: ('T →' U) → 'T [] →' T किसी सरणी के सभी तत्वों में से सबसे छोटा लौटाता है। Operators.min का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
सूची: 'टी सूची →' टी [] आपूर्ति की गई सूची से एक सरणी बनाता है।
Seq: seq <'T> →' T [] आपूर्ति की जाने योग्य वस्तु से एक सरणी बनाता है।
विभाजन: ('टी → बूल) →' टी [] → 'टी [] *' टी [] एक सरणी को दो सरणियों में विभाजित करता है, जिसमें से एक तत्व होता है जिसके लिए आपूर्ति की स्थिति वापस आती है true, और दूसरा जिनके लिए यह वापस आता है false
परमिट: (इंट → इंट) → 'टी [] →' टी [] निर्दिष्ट क्रमपरिवर्तन के अनुसार किसी सरणी के तत्वों को अनुमति देता है।
पिक: ('टी →' यू विकल्प) → 'टी [] →' यू किसी दिए गए सरणी के क्रमिक तत्वों के लिए आपूर्ति किए गए फ़ंक्शन को लागू करता है, पहला परिणाम लौटाता है जहां फ़ंक्शन कुछ x के लिए कुछ (x) देता है। यदि फ़ंक्शन कुछ (x) को कभी नहीं लौटाता है, तो KeyNotFoundException को उठाया जाता है।
कम करें: ('T →' T → 'T) →' T [] → 'T एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और सरणी तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (f i0 i1) ...) iN गणना करता है। यदि सरणी का आकार शून्य है, तो ArgumentException को उठाया जाता है।
कम करें: ('T →' T → 'T) →' T [] → 'T एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f i0 (... (f iN-1 iN)) की गणना करता है। यदि सरणी का आकार शून्य है, तो ArgumentException को उठाया जाता है।
Rev: 'T [] →' T [] एक प्रदत्त सारणी में तत्वों के क्रम को उलट देता है।
स्कैन: ('स्टेट →' टी → 'स्टेट) →' स्टेट → 'टी [] →' स्टेट []] गुना की तरह व्यवहार करता है, लेकिन अंतिम परिणामों के साथ मध्यवर्ती परिणाम लौटाता है।
स्कैनबैक: ('T →' राज्य → 'राज्य) →' T [] → 'राज्य →' राज्य [] तह की तरह व्यवहार करता है, लेकिन अंतिम परिणामों के साथ एक साथ मध्यस्थ परिणाम देता है।
सेट: 'T [] → int →' T → यूनिट एक सरणी का एक तत्व सेट करता है।
सॉर्ट: 'टी [] →' टी [] एक सरणी के तत्वों को सॉर्ट करता है और एक नया एरे देता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
SortBy: ('टी →' की) → 'टी [] →' टी [] किसी फ़ंक्शन के तत्वों को उस प्रकार में बदलने के लिए आपूर्ति की गई फ़ंक्शन का उपयोग करके सॉर्ट करता है जिस पर सॉर्ट ऑपरेशन आधारित है, और एक नया एरे देता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
SortInPlace: 'टी [] → इकाई आपूर्ति की तुलना फ़ंक्शन का उपयोग करके, जगह में सरणी को बदलकर एक सरणी के तत्वों को सॉर्ट करता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
SortInPlaceBy: ('T →' की) → 'T [] → यूनिट कुंजियों के लिए आपूर्ति किए गए प्रक्षेपण का उपयोग करके, जगह में सरणी को बदलकर एक सरणी के तत्वों को सॉर्ट करता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
sortInPlaceWith: ('T →' T → int) → 'T [] → इकाई सरणी में स्थान बदलने के लिए आपूर्ति की तुलना फ़ंक्शन का उपयोग करके एक सरणी के तत्वों को सॉर्ट करता है।
क्रमबद्ध करें: ('T →' T → int) → 'T [] →' T [] आपूर्ति की तुलना फ़ंक्शन का उपयोग करके एक सरणी के तत्वों को सॉर्ट करता है, और एक नया सरणी देता है।
उप: 'T [] → int → int →' T [] एक सरणी बनाता है जिसमें आपूर्ति की गई सबरेंज होती है, जो सूचकांक और लंबाई को शुरू करके निर्दिष्ट होती है।
योग: 'टी [] → ^ टी सरणी में तत्वों का योग लौटाता है।
sumBy: ('T → ^ U) →' T [] → ^ U किसी सरणी के प्रत्येक तत्व पर फ़ंक्शन लागू करके उत्पन्न परिणामों का योग लौटाता है।
सूची: 'टी [] →' टी सूची आपूर्ति की गई सरणी को एक सूची में परिवर्तित करता है।
toSeq: 'T [] → seq <' T> एक अनुक्रम के रूप में आपूर्ति की गई सरणी को देखें।
tryFind: ('T → बूल) →' T [] → 'T विकल्प आपूर्ति की गई सरणी में पहला तत्व देता है जिसके लिए आपूर्ति की गई फ़ंक्शन वापस आती है true। रिटर्नNone यदि ऐसा कोई तत्व मौजूद नहीं है।
tryFindIndex: ('T → बूल) →' T [] → int विकल्प एक सरणी में पहले तत्व के सूचकांक को लौटाता है जो आपूर्ति की स्थिति को संतुष्ट करता है।
tryPick: ('T →' U विकल्प) → 'T [] →' U विकल्प आपूर्ति की गई फ़ंक्शन को दिए गए सरणी के क्रमिक तत्वों पर लागू करता है, और पहला परिणाम देता है जहां फ़ंक्शन कुछ x के लिए कुछ (x) देता है। यदि फ़ंक्शन कुछ वापस नहीं करता है (x),None वापस आ गया है।
अनज़िप: ('T1 *' T2) [] → 'T1 [] *' T2 [] दो सरणियों के टपल में टपल जोड़े की एक सरणी को विभाजित करता है।
unzip3: ('T1 *' T2 * 'T3) [] →' T1 [] * 'T2 [] *' T3 [] तीन सरणियों के टपल में तीन तत्वों के ट्यूल के एक हिस्से को विभाजित करता है।
zeroCreate: int → 'T [] एक ऐसा ऐरे बनाता है, जिसके तत्व शुरू में डिफॉल्ट मान पर सेट होते हैं।
zip: 'T1 [] →' T2 [] → ('T1 *' T2) [] दो सरणियों को एक ऐसे ट्यूपल्स की एक सरणी में मिलाता है जिसमें दो तत्व होते हैं। दो सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
zip3: 'T1 [] →' T2 [] → 'T3 [] → (' T1 * 'T2 * 113' T3) [] तीन सरणियों को एक सारणी में मिलाता है जिसमें तीन तत्व होते हैं। तीन सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।

निम्नलिखित अनुभाग में, हम इनमें से कुछ कार्यात्मकताओं के उपयोग देखेंगे।

क्रियाओं का उपयोग करके ऐरे बनाना

ऐरे मॉड्यूल कई कार्य प्रदान करता है जो खरोंच से एक सरणी बनाते हैं।

  • Array.empty फ़ंक्शन एक नया खाली सरणी बनाता है।

  • Array.create फ़ंक्शन एक निर्दिष्ट आकार का एक सरणी बनाता है और दिए गए मानों के लिए सभी तत्वों को सेट करता है।

  • Array.init फ़ंक्शन एक सरणी बनाता है, तत्वों को उत्पन्न करने के लिए एक आयाम और एक फ़ंक्शन दिया जाता है।

  • Array.zeroCreate फ़ंक्शन एक ऐसा सरणी बनाता है जिसमें सभी तत्व शून्य मान के लिए आरंभिक होते हैं।

  • Array.copy फ़ंक्शन एक नया सरणी बनाता है जिसमें ऐसे तत्व होते हैं जो मौजूदा सरणी से कॉपी किए जाते हैं।

  • Array.sub फंक्शन एक अरेंज के सब अरेंज से एक नया एरे तैयार करता है।

  • Array.append फ़ंक्शन दो मौजूदा सरणियों के संयोजन से एक नया सरणी बनाता है।

  • Array.choose फ़ंक्शन एक नए सरणी में शामिल करने के लिए किसी सरणी के तत्वों का चयन करता है।

  • Array.collect फ़ंक्शन मौजूदा सरणी के प्रत्येक सरणी तत्व पर एक निर्दिष्ट फ़ंक्शन चलाता है और फिर फ़ंक्शन द्वारा उत्पन्न तत्वों को इकट्ठा करता है और उन्हें एक नए सरणी में जोड़ता है।

  • Array.concat फ़ंक्शन सरणियों का एक क्रम लेता है और उन्हें एक एकल सरणी में जोड़ता है।

  • Array.filter फ़ंक्शन एक बूलियन स्थिति फ़ंक्शन लेता है और एक नया सरणी उत्पन्न करता है जिसमें इनपुट सरणी से केवल वे तत्व होते हैं जिनके लिए स्थिति सही है।

  • Array.rev फ़ंक्शन किसी मौजूदा सरणी के क्रम को उल्टा करके एक नया सरणी बनाता है।

निम्नलिखित उदाहरण इन कार्यों को प्रदर्शित करते हैं -

उदाहरण 1

(* using create and set *)
let array1 = Array.create 10 ""
for i in 0 .. array1.Length - 1 do
   Array.set array1 i (i.ToString())
for i in 0 .. array1.Length - 1 do
   printf "%s " (Array.get array1 i)
printfn " "

(* empty array *)
let array2 = Array.empty
printfn "Length of empty array: %d" array2.Length

let array3 = Array.create 10 7.0
printfn "Float Array: %A" array3

(* using the init and zeroCreate *)
let array4 = Array.init 10 (fun index -> index * index)
printfn "Array of squares: %A" array4

let array5 : float array = Array.zeroCreate 10
let (myZeroArray : float array) = Array.zeroCreate 10
printfn "Float Array: %A" array5

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

0 1 2 3 4 5 6 7 8 9
Length of empty array: 0
Float Array: [|7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0|]
Array of squares: [|0; 1; 4; 9; 16; 25; 36; 49; 64; 81|]
Float Array: [|0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0|]

उदाहरण 2

(* creating subarray from element 5 *)
(* containing 15 elements thereon *)

let array1 = [| 0 .. 50 |]
let array2 = Array.sub array1 5 15
printfn "Sub Array:"
printfn "%A" array2

(* appending two arrays *)
let array3 = [| 1; 2; 3; 4|]
let array4 = [| 5 .. 9 |]
printfn "Appended Array:"
let array5 = Array.append array3 array4
printfn "%A" array5

(* using the Choose function *)
let array6 = [| 1 .. 20 |]
let array7 = Array.choose (fun elem -> if elem % 3 = 0 then
                                             Some(float (elem))
                                          else
                                             None) array6
printfn "Array with Chosen elements:"
printfn "%A" array7

(*using the Collect function *)
let array8 = [| 2 .. 5 |]
let array9 = Array.collect (fun elem -> [| 0 .. elem - 1 |]) array8
printfn "Array with collected elements:"
printfn "%A" array9

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

Sub Array:
[|5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15; 16; 17; 18; 19|]
Appended Array:
[|1; 2; 3; 4; 5; 6; 7; 8; 9|]
Array with Chosen elements:
[|3.0; 6.0; 9.0; 12.0; 15.0; 18.0|]
Array with collected elements:
[|0; 1; 0; 1; 2; 0; 1; 2; 3; 0; 1; 2; 3; 4|]

Arrays खोजना

Array.find फ़ंक्शन एक बूलियन फ़ंक्शन लेता है और पहला तत्व देता है जिसके लिए फ़ंक्शन सही लौटाता है, अन्यथा KeyNotFoundException उठाता है।

Array.findIndex फ़ंक्शन समान रूप से काम करता है सिवाय इसके कि वह तत्व के बजाय तत्व के सूचकांक को वापस लौटाता है।

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

Microsoft यह दिलचस्प कार्यक्रम उदाहरण प्रदान करता है, जो किसी दिए गए नंबर की सीमा में पहला तत्व ढूंढता है जो एक पूर्ण वर्ग और साथ ही एक पूर्णांक - है

let array1 = [| 2 .. 100 |]
let delta = 1.0e-10
let isPerfectSquare (x:int) =
   let y = sqrt (float x)
   abs(y - round y) < delta

let isPerfectCube (x:int) =
   let y = System.Math.Pow(float x, 1.0/3.0)
   abs(y - round y) < delta

let element = Array.find (fun elem -> isPerfectSquare elem && isPerfectCube elem) array1

let index = Array.findIndex (fun elem -> isPerfectSquare elem && isPerfectCube elem) array1

printfn "The first element that is both a square and a cube is %d and its index is %d." element index

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

The first element that is both a square and a cube is 64 and its index is 62.

List<'T> वर्ग वस्तुओं की एक दृढ़ता से टाइप की गई सूची का प्रतिनिधित्व करता है जिसे सूचकांक द्वारा पहुँचा जा सकता है।

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

एक उत्परिवर्ती सूची बनाना

सूची का उपयोग कर बनाई गई हैं newकीवर्ड और सूची के निर्माता को कॉल करना। निम्न उदाहरण यह प्रदर्शित करता है -

(* Creating a List *)
open System.Collections.Generic

let booksList = new List<string>()
booksList.Add("Gone with the Wind")
booksList.Add("Atlas Shrugged")
booksList.Add("Fountainhead")
booksList.Add("Thornbirds")
booksList.Add("Rebecca")
booksList.Add("Narnia")

booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])

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

0: Gone with the Wind
1: Atlas Shrugged
2: Fountainhead
3: Thornbirds
4: Rebecca
5: Narnia

सूची (टी) वर्ग

सूची (टी) वर्ग उन वस्तुओं की एक दृढ़ता से टाइप की गई सूची का प्रतिनिधित्व करता है जिन्हें सूचकांक द्वारा एक्सेस किया जा सकता है। यह सूचियों को खोजने, छांटने और हेरफेर करने के तरीके प्रदान करता है।

निम्न तालिकाएँ गुण, निर्माता और सूची (T) वर्ग की विधियाँ प्रदान करती हैं -

गुण

संपत्ति विवरण
क्षमता हो जाता है या आंतरिक डेटा संरचना को आकार दिए बिना उन तत्वों की कुल संख्या निर्धारित करता है जिन्हें धारण कर सकते हैं।
गिनती सूची (T) में निहित तत्वों की संख्या प्राप्त करता है।
मद निर्दिष्ट इंडेक्स पर तत्व प्राप्त या सेट करता है।

कंस्ट्रक्टर्स

निर्माता विवरण
सूची (टी) () सूची (T) श्रेणी का एक नया उदाहरण प्रारंभ करता है जो खाली है और डिफ़ॉल्ट प्रारंभिक क्षमता है।
सूची (टी) (IEnumerable (टी)) सूची (T) वर्ग का एक नया उदाहरण शुरू करता है जिसमें निर्दिष्ट संग्रह से कॉपी किए गए तत्व होते हैं और कॉपी किए गए तत्वों की संख्या को समायोजित करने की पर्याप्त क्षमता होती है।
सूची (टी) (Int32) सूची (T) श्रेणी का एक नया उदाहरण प्रारंभ करता है जो खाली है और इसमें निर्दिष्ट प्रारंभिक क्षमता है।

तरीका

तरीकों विवरण
जोड़ना सूची (T) के अंत में एक वस्तु जोड़ता है।
AddRange निर्दिष्ट संग्रह के तत्वों को सूची (टी) के अंत में जोड़ता है।
AsReadOnly वर्तमान संग्रह के लिए केवल पढ़ने के लिए IList (T) आवरण देता है।
BinarySearch (टी) डिफ़ॉल्ट तुलना करने वाले तत्व का उपयोग करके संपूर्ण सॉर्ट की गई सूची (T) को खोजता है और तत्व के शून्य-आधारित सूचकांक को वापस करता है।
बाइनरीसर्च (T, IComparer (T)) निर्दिष्ट तुलनित्र का उपयोग करने वाले तत्व के लिए संपूर्ण क्रमबद्ध सूची (T) को खोजता है और तत्व के शून्य-आधारित सूचकांक को वापस करता है।
बाइनरीसर्च (Int32, Int32, T, IComparer (T)) निर्दिष्ट तुलनित्र का उपयोग करते हुए तत्व के लिए क्रमबद्ध सूची (टी) में तत्वों की एक श्रृंखला की खोज करता है और तत्व के शून्य-आधारित सूचकांक को वापस करता है।
स्पष्ट सूची (T) से सभी तत्वों को निकालता है।
शामिल यह निर्धारित करता है कि कोई तत्व सूची (T) में है या नहीं।
ConvertAll (TOutput) वर्तमान सूची (T) में तत्वों को दूसरे प्रकार में परिवर्तित करता है, और एक सूची देता है जिसमें परिवर्तित तत्व होते हैं।
CopyTo (टी []) लक्ष्य सूची की शुरुआत में एक संगत एक आयामी सरणी के लिए पूरी सूची (टी) की प्रतिलिपि बनाता है।
CopyTo (T [], Int32) लक्ष्य सूची के निर्दिष्ट सूचकांक पर शुरू करके, एक सुसंगत एक-आयामी सरणी में संपूर्ण सूची (T) की प्रतिलिपि बनाता है।
CopyTo (Int32, T [], Int32, Int32) टारगेट के निर्दिष्ट इंडेक्स पर शुरू करते हुए लिस्ट (T) से तत्वों की एक श्रृंखला को एक संगत डायमेंशनल सरणी में कॉपी करता है।
बराबरी (वस्तु) निर्धारित करता है कि निर्दिष्ट वस्तु वर्तमान वस्तु के बराबर है या नहीं। (ऑब्जेक्ट से निहित)
मौजूद निर्धारित करता है कि सूची (T) में ऐसे तत्व हैं जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाते हैं।
अंतिम रूप किसी ऑब्जेक्ट को कचरा संग्रह (ऑब्जेक्ट से इनहेरिट) द्वारा पुनर्प्राप्त करने से पहले संसाधनों को मुक्त करने और अन्य सफाई कार्यों को करने की अनुमति देता है।
खोज एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और संपूर्ण सूची (T) के भीतर पहली घटना देता है।
सब ढूँढ़ो निर्दिष्ट प्रेडिक्ट द्वारा परिभाषित शर्तों से मेल खाने वाले सभी तत्वों को पुनः प्राप्त करता है।
FindIndex (विधेय (टी)) एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और पूरी सूची (टी) के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करता है।
FindIndex (Int32, Predicate (T)) एक तत्व की खोज जो निर्दिष्ट विधेय द्वारा परिभाषित स्थितियों से मेल खाती है, और सूची (टी) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करती है जो निर्दिष्ट सूचकांक से अंतिम तत्व तक फैली हुई है।
FindIndex (Int32, Int32, Predicate (T)) एक तत्व के लिए खोजें जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती हैं, और सूची (टी) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करती है जो निर्दिष्ट सूचकांक से शुरू होती है और इसमें निर्दिष्ट संख्या शामिल होती है।
FindLast एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और संपूर्ण सूची (T) के भीतर अंतिम घटना देता है।
FindLastIndex (विधेय (टी)) एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और संपूर्ण सूची (टी) के भीतर अंतिम घटना के शून्य-आधारित सूचकांक को लौटाता है।
FindLastIndex (Int32, Predicate (T)) एक तत्व के लिए खोज जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती है, और सूची (टी) में तत्वों की सीमा के भीतर अंतिम घटना के शून्य-आधारित सूचकांक को वापस करती है जो पहले तत्व से निर्दिष्ट सूचकांक तक फैली हुई है।
FindLastIndex (Int32, Int32, Predicate (T)) एक तत्व के लिए खोज जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती है, और सूची (टी) में तत्वों की सीमा के भीतर अंतिम घटना का शून्य-आधारित सूचकांक लौटाता है जिसमें तत्वों की निर्दिष्ट संख्या होती है और निर्दिष्ट सूचकांक पर समाप्त होती है।
प्रत्येक के लिए सूची (टी) के प्रत्येक तत्व पर निर्दिष्ट कार्रवाई करता है।
GetEnumerator एक एन्यूमरेटर लौटाता है जो सूची (टी) के माध्यम से पुनरावृत्त होता है।
GetHashCode डिफ़ॉल्ट हैश फ़ंक्शन के रूप में कार्य करता है। (ऑब्जेक्ट से निहित)
GetRange स्रोत सूची (T) में तत्वों की एक श्रेणी की उथली प्रतिलिपि बनाता है।
GetType वर्तमान उदाहरण के प्रकार प्राप्त होते हैं। (ऑब्जेक्ट से निहित)
IndexOf (टी) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और संपूर्ण सूची (T) के भीतर पहली घटना के शून्य-आधारित सूचकांक देता है।
IndexOf (T, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करता है जो निर्दिष्ट सूचकांक से अंतिम तत्व तक फैली हुई है।
IndexOf (T, Int32, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित इंडेक्स को वापस करता है जो निर्दिष्ट इंडेक्स पर शुरू होता है और इसमें तत्वों की निर्दिष्ट संख्या होती है।
डालने निर्दिष्ट सूचकांक पर सूची (T) में एक तत्व सम्मिलित करता है।
InsertRange एक सूची के तत्वों को निर्दिष्ट सूचकांक में सूची (टी) में सम्मिलित करता है।
LastIndexOf (टी) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और संपूर्ण सूची (T) के भीतर अंतिम घटना का शून्य-आधारित सूचकांक देता है।
LastIndexOf (T, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर अंतिम घटना का शून्य-आधारित सूचकांक देता है जो पहले तत्व से निर्दिष्ट सूचकांक तक फैली हुई है।
LastIndexOf (T, Int32, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर अंतिम घटना का शून्य-आधारित सूचकांक लौटाता है जिसमें तत्वों की निर्दिष्ट संख्या होती है और निर्दिष्ट सूचकांक पर समाप्त होती है।
MemberwiseClone वर्तमान वस्तु की एक उथली प्रति तैयार करती है। (ऑब्जेक्ट से निहित)
हटाना किसी विशिष्ट ऑब्जेक्ट की पहली घटना को सूची (T) से निकालता है।
सभी हटाएं निर्दिष्ट predicate द्वारा परिभाषित शर्तों से मेल खाने वाले सभी तत्वों को निकालता है।
RemoveAt सूची (टी) के निर्दिष्ट सूचकांक पर तत्व को निकालता है।
RemoveRange सूची (T) से कई तत्वों को निकालता है।
उलटना() संपूर्ण सूची (T) में तत्वों के क्रम को उलट देता है।
रिवर्स (Int32, Int32) निर्दिष्ट सीमा में तत्वों के क्रम को उलट देता है।
क्रमबद्ध करें () डिफ़ॉल्ट सूची का उपयोग करके संपूर्ण सूची (T) में तत्वों को भेजता है।
क्रमबद्ध करें (तुलना (टी)) निर्दिष्ट सिस्टम का उपयोग करके संपूर्ण सूची (T) में तत्वों को जोड़ता है। तुलना (टी)।
क्रमबद्ध करें (IComparer (टी)) निर्दिष्ट सूची का उपयोग करके संपूर्ण सूची (T) में तत्वों को जोड़ता है।
क्रमबद्ध करें (Int32, Int32, IComparer (T)) निर्दिष्ट तुलनित्र का उपयोग करते हुए तत्वों की एक सूची में तत्वों को सूची (T) में रखता है।
toArray सूची (T) के तत्वों को एक नए सरणी में कॉपी करता है।
तार एक स्ट्रिंग रिटर्न जो मौजूदा वस्तु का प्रतिनिधित्व करता है। (ऑब्जेक्ट से निहित)
TrimExcess सूची (T) में तत्वों की वास्तविक संख्या की क्षमता निर्धारित करता है, यदि वह संख्या एक सीमा मूल्य से कम है।
TrueForAll निर्धारित करता है कि सूची (T) में प्रत्येक तत्व निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है या नहीं।

उदाहरण

(* Creating a List *)
open System.Collections.Generic

let booksList = new List<string>()
booksList.Add("Gone with the Wind")
booksList.Add("Atlas Shrugged")
booksList.Add("Fountainhead")
booksList.Add("Thornbirds")
booksList.Add("Rebecca")
booksList.Add("Narnia")

printfn"Total %d books" booksList.Count
booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])
booksList.Insert(2, "Roots")

printfn("after inserting at index 2")
printfn"Total %d books" booksList.Count

booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])
booksList.RemoveAt(3)

printfn("after removing from index 3")
printfn"Total %d books" booksList.Count

booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])

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

Total 6 books
0: Gone with the Wind
1: Atlas Shrugged
2: Fountainhead
3: Thornbirds
4: Rebecca
5: Narnia
after inserting at index 2
Total 7 books
0: Gone with the Wind
1: Atlas Shrugged
2: Roots
3: Fountainhead
4: Thornbirds
5: Rebecca
6: Narnia
after removing from index 3
Total 6 books
0: Gone with the Wind
1: Atlas Shrugged
2: Roots
3: Thornbirds
4: Rebecca
5: Narnia

Dictionary<'TKey, 'TValue> क्लास एफ # मैप डेटा संरचना का परस्पर एनालॉग है और इसमें समान कार्य होते हैं।

F # में मैप अध्याय से रिकैपिटुलेटिंग, एक मैप एक विशेष प्रकार का सेट है जो मूल्यों को कुंजी के साथ जोड़ता है।

एक उत्परिवर्ती शब्दकोश का निर्माण

का उपयोग करते हुए उत्परिवर्ती शब्दकोशों का निर्माण किया जाता है newकीवर्ड और सूची के निर्माता को कॉल करना। निम्न उदाहरण यह प्रदर्शित करता है -

open System.Collections.Generic
let dict = new Dictionary<string, string>()
dict.Add("1501", "Zara Ali")
dict.Add("1502","Rishita Gupta")
dict.Add("1503","Robin Sahoo")
dict.Add("1504","Gillian Megan")
printfn "Dictionary - students: %A" dict

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

Dictionary - students: seq
[[1501, Zara Ali]; [1502, Rishita Gupta]; [1503, Robin Sahoo];
[1504, Gillian Megan]]

शब्दकोश (TKey, TValue) कक्षा

डिक्शनरी (TKey, TValue) कक्षा कुंजियों और मूल्यों के संग्रह का प्रतिनिधित्व करती है।

निम्न तालिकाएँ गुण, निर्माता और सूची (T) वर्ग की विधियाँ प्रदान करती हैं -

गुण

संपत्ति विवरण
comparer IEqualityComparer (T) हो जाता है जो शब्दकोश के लिए कुंजियों की समानता निर्धारित करने के लिए उपयोग किया जाता है।
गिनती शब्दकोश (TKey, TValue) में निहित कुंजी / मूल्य जोड़े की संख्या प्राप्त होती है।
मद निर्दिष्ट कुंजी के साथ जुड़े मूल्य को प्राप्त या निर्धारित करता है।
चांबियाँ शब्दकोश (TKey, TValue) में कुंजियों वाला एक संग्रह मिलता है।
मूल्यों शब्दकोश (TKey, TValue) में मूल्यों से युक्त एक संग्रह प्राप्त होता है।

कंस्ट्रक्टर्स

कंस्ट्रक्टर्स विवरण
शब्दकोश (TKey, TValue) () का एक नया उदाहरण प्रारंभ करता है Dictionary(TKey, TValue) जो वर्ग खाली है, उसमें डिफ़ॉल्ट प्रारंभिक क्षमता है, और कुंजी प्रकार के लिए डिफ़ॉल्ट समानता तुलनित्र का उपयोग करता है।
शब्दकोश (TKey, TValue) (IDEDIA (TKey, TValue)) का एक नया उदाहरण प्रारंभ करता है Dictionary(TKey, TValue) वह वर्ग जिसमें निर्दिष्ट से कॉपी किए गए तत्व हैं IDictionary(TKey, TValue) और कुंजी प्रकार के लिए डिफ़ॉल्ट समानता तुलनित्र का उपयोग करता है।
शब्दकोश (TKey, TValue) (IEqualityComparer (TKey)) का एक नया उदाहरण प्रारंभ करता है Dictionary(TKey, TValue) क्लास जो खाली है, उसमें डिफ़ॉल्ट प्रारंभिक क्षमता है, और निर्दिष्ट का उपयोग करता है IEqualityComparer(T).
शब्दकोश (TKey, TValue) (Int32) का एक नया उदाहरण प्रारंभ करता है Dictionary(TKey, TValue) वर्ग जो खाली है, में निर्दिष्ट प्रारंभिक क्षमता है, और कुंजी प्रकार के लिए डिफ़ॉल्ट समानता तुलनित्र का उपयोग करता है।
शब्दकोश (TKey, TValue) (IDEDIA (TKey, TValue), IEqualityComparer (TKey)) का एक नया उदाहरण प्रारंभ करता है Dictionary(TKey, TValue) वह वर्ग जिसमें निर्दिष्ट से कॉपी किए गए तत्व हैं IDictionary(TKey, TValue) और निर्दिष्ट का उपयोग करता है IEqualityComparer(T).
शब्दकोश (TKey, TValue) (Int32, IEqualityComparer (TKey)) का एक नया उदाहरण प्रारंभ करता है Dictionary(TKey, TValue) वर्ग जो खाली है, में निर्दिष्ट प्रारंभिक क्षमता है, और निर्दिष्ट का उपयोग करता है IEqualityComparer(T).
डिक्शनरी (टीके, टीवील्यू) (सीरियलाइजेशनइन्फो, स्ट्रीमिंगकोटेक्स्ट) का एक नया उदाहरण प्रारंभ करता है ictionary(TKey, TValue) क्रमबद्ध डेटा के साथ वर्ग।

तरीकों

तरीका विवरण
जोड़ना शब्दकोश में निर्दिष्ट कुंजी और मूल्य जोड़ता है।
स्पष्ट शब्दकोश (TKey, TValue) से सभी कुंजी और मान निकालता है।
ContainsKey यह निर्धारित करता है कि क्या शब्दकोश (TKey, TValue) में निर्दिष्ट कुंजी है।
ContainsValue यह निर्धारित करता है कि क्या शब्दकोश (TKey, TValue) में एक विशिष्ट मूल्य है।
बराबरी (वस्तु) निर्धारित करता है कि निर्दिष्ट वस्तु वर्तमान वस्तु के बराबर है या नहीं। (ऑब्जेक्ट से निहित)
अंतिम रूप किसी ऑब्जेक्ट को कचरा संग्रह द्वारा पुनर्प्राप्त करने से पहले संसाधनों को मुक्त करने और अन्य सफाई कार्यों को करने की अनुमति देता है। (ऑब्जेक्ट से निहित)
GetEnumerator एक एन्यूमरेटर लौटाता है जो डिक्शनरी (TKey, TValue) के माध्यम से प्रसारित होता है।
GetHashCode डिफ़ॉल्ट हैश फ़ंक्शन के रूप में कार्य करता है। (ऑब्जेक्ट से निहित)
GetObjectData System.Runtime.Serialization.ISerializable इंटरफ़ेस को लागू करता है और शब्दकोश (TKey, TValue) उदाहरण को क्रमबद्ध करने के लिए आवश्यक डेटा देता है।
GetType वर्तमान उदाहरण के प्रकार प्राप्त होते हैं। (ऑब्जेक्ट से निहित)
MemberwiseClone वर्तमान वस्तु की एक उथली प्रति तैयार करती है। (ऑब्जेक्ट से निहित)
OnDeserialization System.Runtime.Serialization.ISerializable इंटरफ़ेस को लागू करता है और deserialization इवेंट उठाता है जब deserialization पूरा होता है।
हटाना शब्दकोश (TKey, TValue) से निर्दिष्ट कुंजी के साथ मान निकालता है।
तार एक स्ट्रिंग रिटर्न जो मौजूदा वस्तु का प्रतिनिधित्व करता है। (ऑब्जेक्ट से निहित)
TryGetValue निर्दिष्ट कुंजी के साथ जुड़े मूल्य हो जाता है।

उदाहरण

open System.Collections.Generic
let dict = new Dictionary<string, string>()

dict.Add("1501", "Zara Ali")
dict.Add("1502","Rishita Gupta")
dict.Add("1503","Robin Sahoo")
dict.Add("1504","Gillian Megan")

printfn "Dictionary - students: %A" dict
printfn "Total Number of Students: %d" dict.Count
printfn "The keys: %A" dict.Keys
printf"The Values: %A" dict.Values

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

Dictionary - students: seq
[[1501, Zara Ali]; [1502, Rishita Gupta]; [1503, Robin Sahoo];
[1504, Gillian Megan]]
Total Number of Students: 4
The keys: seq ["1501"; "1502"; "1503"; "1504"]
The Values: seq ["Zara Ali"; "Rishita Gupta"; "Robin Sahoo"; "Gillian Megan"]

मूल इनपुट आउटपुट में शामिल हैं -

  • से पढ़ना और कंसोल में लिखना।
  • फाइल में से पढ़ना और लिखना।

Core.Printf मॉड्यूल

हम इस्तेमाल किया है printf और printfn कंसोल में लिखने के लिए कार्य करता है। इस भाग में, हम इसके विवरण पर गौर करेंगेPrintf F # का मॉड्यूल।

उपरोक्त कार्यों के अलावा, F # के Core.Printf मॉड्यूल में प्लेसहोल्डर के रूप में% मार्करों का उपयोग करके मुद्रण और स्वरूपण के लिए कई अन्य तरीके हैं। निम्न तालिका संक्षिप्त विवरण के साथ विधियों को दिखाती है -

मूल्य विवरण
bprintf: StringBuilder → बिल्डरफ़ॉर्मैट <'T> →' T एक StringBuilder के लिए प्रिंट।
eprintf: TextWriterFormat <'T> →' T प्रिंटर्स ने आउटपुट को स्टेदर पर स्वरूपित किया।
eprintfn: TextWriterFormat <'T> →' T प्रिंटर्स ने स्टेटर्र को आउटपुट स्वरूपित किया, जिसमें एक नई रेखा जोड़ी गई।
failwithf: StringFormat <'T,' परिणाम> → 'T एक स्ट्रिंग बफर को प्रिंट करता है और दिए गए परिणाम के साथ एक अपवाद उठाता है।
fprintf: TextWriter → TextWriterFormat <'T> →' T एक पाठ लेखक को प्रिंट करता है।
fprintfn: TextWriter → TextWriterFormat <'T> →' T एक टेक्स्ट लेखक को प्रिंट करता है, एक नई पंक्ति जोड़ता है।
kbprintf: (इकाई → 'परिणाम) → StringBuilder → बिल्डरफ़ॉर्मैट <' T, 'परिणाम> →' T Bprintf की तरह, लेकिन परिणाम उत्पन्न करने के लिए निर्दिष्ट फ़ंक्शन को कॉल करता है।
kfprintf: (इकाई → 'परिणाम) → TextWriter → TextWriterFormat <' T, 'परिणाम> →' T Fprintf की तरह, लेकिन परिणाम उत्पन्न करने के लिए निर्दिष्ट फ़ंक्शन को कॉल करता है।
kprintf: (string → 'Result) → StringFormat <' T, 'Result> →' T प्रिंटफ की तरह, लेकिन परिणाम उत्पन्न करने के लिए निर्दिष्ट फ़ंक्शन को कॉल करता है। उदाहरण के लिए, चैनल पर सभी आउटपुट दर्ज किए जाने के बाद ये मुद्रण बल को फ्लश करते हैं, लेकिन पहले नहीं।
ksprintf: (string → 'Result) → StringFormat <' T, 'Result> →' T स्प्रिंटफ की तरह, लेकिन परिणाम उत्पन्न करने के लिए निर्दिष्ट फ़ंक्शन को कॉल करता है।
प्रिंटफ: टेक्सटाइटरफार्मेट <'T> →' T प्रिंट्स ने आउटपुट को स्टडआउट में स्वरूपित किया।
Printfn: टेक्स्टवॉर्मफॉर्म <<टी> → 'टी प्रिंट्स ने आउटपुट को स्टडआउट में जोड़ा, एक नई पंक्ति को जोड़ते हुए।
स्प्रिंटफ: स्ट्रिंगफार्मेट <'टी> →' टी आंतरिक स्ट्रिंग बफर का उपयोग करके एक स्ट्रिंग को प्रिंट करता है और एक स्ट्रिंग के रूप में परिणाम देता है।

प्रारूप विनिर्देशों

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

ये प्रारूप प्लेसहोल्डर्स को दर्शाने वाले% मार्करों के साथ तार हैं।

प्रारूप प्लेसहोल्डर्स का सिंटैक्स है -

%[flags][width][.precision][type]

type इसकी व्याख्या इस प्रकार है -

प्रकार विवरण
% ख प्रारूप a bool, के रूप में स्वरूपित किया गया true या false
%सी एक चरित्र बनाता है।
% s प्रारूप a string, किसी भी भागने के पात्रों की व्याख्या के बिना, इसकी सामग्री के रूप में स्वरूपित।
% d,% i यदि किसी मूल पूर्णांक प्रकार पर हस्ताक्षर किए गए हैं, तो किसी भी मूल पूर्णांक प्रकार को दशमलव पूर्णांक के रूप में स्वरूपित किया जाता है।
% u किसी भी मूल पूर्णांक प्रकार को स्वरूपित एक अहस्ताक्षरित दशमलव पूर्णांक के रूप में स्वरूपित करता है।
%एक्स किसी भी मूल पूर्णांक प्रकार को एक अहस्ताक्षरित हेक्साडेसिमल पूर्णांक के रूप में स्वरूपित किया जाता है, जिसमें f के माध्यम से लोअरकेस अक्षरों का उपयोग किया जाता है।
%एक्स किसी भी मूल पूर्णांक प्रकार को एक अहस्ताक्षरित हेक्साडेसिमल पूर्णांक के रूप में स्वरूपित किया जाता है, बड़े अक्षरों का उपयोग करके ए के माध्यम से।
% ओ किसी भी मूल पूर्णांक प्रकार को स्वरूपित एक अहस्ताक्षरित अष्टक पूर्णांक के रूप में स्वरूपित करता है।
% ई,% ई,% एफ,% एफ,% जी,% जी किसी भी मूल फ़्लोटिंग पॉइंट प्रकार को प्रारूपित करता है (float, float32) सी-शैली फ्लोटिंग पॉइंट प्रारूप विनिर्देशों का उपयोग करके स्वरूपित किया गया।
% ई,% ई फॉर्म पर हस्ताक्षर किए गए मूल्य के प्रारूप [-] d.dddde [साइन] ddd जहां d एक एकल दशमलव अंक है, dddd एक या अधिक दशमलव अंक है, ddd बिल्कुल तीन दशमलव अंक है, और साइन + या - है।
% च फॉर्म पर हस्ताक्षर किए गए मूल्य के प्रारूप [-] dddd.dddd, जहां dddd एक या अधिक दशमलव अंक हैं। दशमलव बिंदु से पहले अंकों की संख्या संख्या के परिमाण पर निर्भर करती है, और दशमलव बिंदु के बाद अंकों की संख्या अनुरोधित परिशुद्धता पर निर्भर करती है।
% G,% G च या ई प्रारूप में मुद्रित हस्ताक्षरित प्रारूप, जो भी दिए गए मूल्य और परिशुद्धता के लिए अधिक कॉम्पैक्ट है।
%म स्वरूप एक दशमलव मान।
% हे किसी भी मूल्य को प्रारूपित करता है, जो वस्तु को बॉक्सिंग करके प्रिंट करता है और उसका उपयोग करता है ToString तरीका।
% ए,% + ए डिफ़ॉल्ट लेआउट सेटिंग्स के साथ मुद्रित किसी भी मूल्य को प्रारूपित करता है। आंतरिक और निजी अभ्यावेदन के साथ विभेदित संघों की संरचना को मुद्रित करने के लिए% + A का उपयोग करें।
%ए

एक सामान्य प्रारूप निर्दिष्टकर्ता को दो तर्कों की आवश्यकता होती है। पहला तर्क एक फ़ंक्शन है जो दो तर्कों को स्वीकार करता है: पहला, दिए गए स्वरूपण फ़ंक्शन (उदाहरण के लिए, एक TextWriter) के लिए उपयुक्त प्रकार का एक संदर्भ पैरामीटर, और दूसरा, प्रिंट करने के लिए एक मान और जो या तो उपयुक्त पाठ को आउटपुट या रिटर्न करता है।

दूसरा तर्क मुद्रित करने के लिए विशेष मूल्य है।

% टी एक सामान्य प्रारूप निर्दिष्टकर्ता को एक तर्क की आवश्यकता होती है: एक फ़ंक्शन जो दिए गए स्वरूपण फ़ंक्शन (aTextWriter) के लिए उपयुक्त प्रकार के संदर्भ पैरामीटर को स्वीकार करता है और जो या तो उपयुक्त पाठ को आउटपुट या रिटर्न करता है। मूल पूर्णांक प्रकार हैंbyte, sbyte, int16, uint16, int32, uint32, int64, uint64, nativeint, तथा unativeint. बेसिक फ्लोटिंग पॉइंट प्रकार हैं float तथा float32.

widthएक वैकल्पिक पैरामीटर है। यह एक पूर्णांक है जो परिणाम की न्यूनतम चौड़ाई को इंगित करता है। उदाहरण के लिए,% 5d 5 वर्णों के कम से कम रिक्त स्थान के साथ पूर्णांक को प्रिंट करता है।

वैध flags निम्नलिखित तालिका में वर्णित हैं -

मूल्य विवरण
0 आवश्यक चौड़ाई बनाने के लिए रिक्त स्थान के बजाय शून्य जोड़ने के लिए निर्दिष्ट करता है।
- निर्दिष्ट चौड़ाई के भीतर परिणाम को सही ठहराने के लिए निर्दिष्ट करता है।
+ यदि संख्या धनात्मक है (ऋणात्मक संख्याओं के लिए a - चिन्ह से मिलान करने के लिए) तो + वर्ण जोड़ने के लिए निर्दिष्ट करता है।
'' (अंतरिक्ष) यदि नंबर पॉजिटिव है (नकारात्मक संख्याओं के लिए साइन-इन - मैच के लिए) एक अतिरिक्त स्थान जोड़ने के लिए निर्दिष्ट करता है।
# अमान्य।

उदाहरण

printf "Hello "
printf "World"
printfn ""
printfn "Hello "
printfn "World"
printf "Hi, I'm %s and I'm a %s" "Rohit" "Medical Student"

printfn "d: %f" 212.098f
printfn "e: %f" 504.768f

printfn "x: %g" 212.098f
printfn "y: %g" 504.768f

printfn "x: %e" 212.098f
printfn "y: %e" 504.768f
printfn "True: %b" true

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

Hello World
Hello
World
Hi, I'm Rohit and I'm a Medical Studentd: 212.098000
e: 504.768000
x: 212.098
y: 504.768
x: 2.120980e+002
y: 5.047680e+002
True: true

कंसोल क्लास

यह वर्ग .NET फ्रेमवर्क का एक हिस्सा है। यह सांत्वना अनुप्रयोगों के लिए मानक इनपुट, आउटपुट और त्रुटि धाराओं का प्रतिनिधित्व करता है।

यह कंसोल में पढ़ने और लिखने के लिए विभिन्न तरीके प्रदान करता है। निम्न तालिका विधियों को दिखाती है -

तरीका विवरण
बीप () कंसोल स्पीकर के माध्यम से एक बीप की आवाज को बजाता है।
Beep (Int32, Int32) कंसोल स्पीकर के माध्यम से एक निर्दिष्ट आवृत्ति और अवधि के बीप की आवाज को बजाता है।
स्पष्ट कंसोल बफ़र और प्रदर्शन जानकारी की संगत कंसोल विंडो साफ़ करता है।
MoveBufferArea (Int32, Int32, Int32, Int32, Int32, Int32) एक निर्दिष्ट गंतव्य क्षेत्र के लिए स्क्रीन बफर के एक निर्दिष्ट स्रोत क्षेत्र की प्रतिलिपि बनाता है।
MoveBufferArea (Int32, Int32, Int32, Int32, Int32, Int32, Char, ConsoleColor, ConsoleColor) एक निर्दिष्ट गंतव्य क्षेत्र के लिए स्क्रीन बफर के एक निर्दिष्ट स्रोत क्षेत्र की प्रतिलिपि बनाता है।
OpenStandardError () मानक त्रुटि स्ट्रीम प्राप्त करता है।
OpenStandardError (Int32) मानक त्रुटि स्ट्रीम प्राप्त करता है, जो एक निर्दिष्ट बफ़र आकार पर सेट होता है।
OpenStandardInput () मानक इनपुट स्ट्रीम प्राप्त करता है।
OpenStandardInput (Int32) मानक इनपुट स्ट्रीम को प्राप्त करता है, जो एक निर्दिष्ट बफर आकार पर सेट होता है।
OpenStandardOutput () मानक आउटपुट स्ट्रीम प्राप्त करता है।
OpenStandardOutput (Int32) मानक आउटपुट स्ट्रीम को प्राप्त करता है, जो एक निर्दिष्ट बफर आकार पर सेट होता है।
पढ़ें मानक इनपुट स्ट्रीम से अगले वर्ण को पढ़ता है।
कुंजी पढ़ें() उपयोगकर्ता द्वारा दबाए गए अगले वर्ण या फ़ंक्शन कुंजी को प्राप्त करता है। प्रेस की गई कुंजी कंसोल विंडो में प्रदर्शित होती है।
ReadKey (बूलियन) उपयोगकर्ता द्वारा दबाए गए अगले वर्ण या फ़ंक्शन कुंजी को प्राप्त करता है। प्रेस की गई कुंजी वैकल्पिक रूप से कंसोल विंडो में प्रदर्शित होती है।
पढ़ने के लिए लाइन मानक इनपुट स्ट्रीम से वर्णों की अगली पंक्ति पढ़ता है।
ResetColor अग्रभूमि और पृष्ठभूमि कंसोल रंगों को उनकी चूक पर सेट करता है।
SetBufferSize निर्दिष्ट मानों के लिए स्क्रीन बफर क्षेत्र की ऊंचाई और चौड़ाई निर्धारित करता है।
SetCursorPosition कर्सर की स्थिति सेट करता है।
SetError निर्दिष्ट TextWriter ऑब्जेक्ट में त्रुटि गुण सेट करता है ।
शुरु होना सेट संपत्ति में निर्दिष्ट TextReader ऑब्जेक्ट के लिए।
प्रस्थान करना निर्दिष्ट TextWriter ऑब्जेक्ट के लिए आउट गुण सेट करता है ।
SetWindowPosition स्क्रीन बफर के सापेक्ष कंसोल विंडो की स्थिति सेट करता है।
SetWindowSize कंसोल विंडो की ऊंचाई और चौड़ाई निर्दिष्ट मानों के लिए सेट करता है।
लिखें (बूलियन) मानक आउटपुट स्ट्रीम में निर्दिष्ट बूलियन मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (चार) निर्दिष्ट यूनिकोड वर्ण मान मानक आउटपुट स्ट्रीम में लिखता है।
लिखें (चार []) यूनिकोड वर्णों के निर्दिष्ट सरणी को मानक आउटपुट स्ट्रीम में लिखते हैं।
लिखें (दशमलव) मानक आउटपुट स्ट्रीम में निर्दिष्ट दशमलव मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (डबल) मानक आउटपुट स्ट्रीम में निर्दिष्ट डबल-सटीक फ़्लोटिंग-पॉइंट मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (Int32) मानक आउटपुट स्ट्रीम में निर्दिष्ट 32-बिट हस्ताक्षरित पूर्णांक मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (Int64) मानक आउटपुट स्ट्रीम में निर्दिष्ट 64-बिट हस्ताक्षरित पूर्णांक मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (वस्तु) मानक आउटपुट स्ट्रीम में निर्दिष्ट ऑब्जेक्ट के पाठ प्रतिनिधित्व को लिखता है।
लिखें (अकेली) मानक आउटपुट स्ट्रीम में निर्दिष्ट एकल-सटीक फ़्लोटिंग-पॉइंट मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (स्ट्रिंग) निर्दिष्ट स्ट्रिंग मान मानक आउटपुट स्ट्रीम में लिखता है।
लिखें (UInt32) मानक आउटपुट स्ट्रीम में निर्दिष्ट 32-बिट अहस्ताक्षरित पूर्णांक मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (UInt64) मानक आउटपुट स्ट्रीम में निर्दिष्ट 64-बिट अहस्ताक्षरित पूर्णांक मान का पाठ प्रतिनिधित्व लिखता है।
लिखें (स्ट्रिंग, ऑब्जेक्ट) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में निर्दिष्ट ऑब्जेक्ट के पाठ प्रतिनिधित्व को लिखता है।
लिखें (स्ट्रिंग, ऑब्जेक्ट []) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में वस्तुओं के निर्दिष्ट सरणी का पाठ प्रतिनिधित्व लिखता है।
लिखें (चार [], Int32, Int32) मानक आउटपुट स्ट्रीम में यूनिकोड वर्णों की निर्दिष्ट उपकथा लिखता है।
लिखें (स्ट्रिंग, ऑब्जेक्ट, ऑब्जेक्ट) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में निर्दिष्ट ऑब्जेक्ट के पाठ प्रतिनिधित्व को लिखता है।
लिखें (स्ट्रिंग, ऑब्जेक्ट, ऑब्जेक्ट, ऑब्जेक्ट) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में निर्दिष्ट ऑब्जेक्ट के पाठ प्रतिनिधित्व को लिखता है।
लिखें (स्ट्रिंग, ऑब्जेक्ट, ऑब्जेक्ट, ऑब्जेक्ट, ऑब्जेक्ट) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में निर्दिष्ट ऑब्जेक्ट्स और चर-लंबाई पैरामीटर सूची के पाठ प्रतिनिधित्व को लिखता है।
पंक्ति लिखो() मानक आउटपुट स्ट्रीम में वर्तमान लाइन टर्मिनेटर लिखता है।
WriteLine (बूलियन) निर्दिष्ट बूलियन मान का पाठ प्रतिनिधित्व लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम तक।
WriteLine (चार) निर्दिष्ट यूनिकोड चरित्र को लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मान मानक आउटपुट स्ट्रीम को देता है।
WriteLine (चार []) यूनिकोड वर्णों के निर्दिष्ट सरणी को लिखता है, उसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम को।
WriteLine (दशमलव) निर्दिष्ट दशमलव मान के पाठ प्रतिनिधित्व को लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम को।
WriteLine (डबल) निर्दिष्ट डबल-परिशुद्धता फ़्लोटिंग-पॉइंट मान के पाठ प्रतिनिधित्व को लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम को।
WriteLine (Int32) निर्दिष्ट 32-बिट हस्ताक्षरित पूर्णांक मान के पाठ प्रतिनिधित्व को लिखता है, इसके बाद मानक आउटपुट स्ट्रीम में वर्तमान लाइन टर्मिनेटर, होता है।
WriteLine (Int64) निर्दिष्ट 64-बिट हस्ताक्षरित पूर्णांक मान के पाठ प्रतिनिधित्व को लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम को।
WriteLine (वस्तु) निर्दिष्ट ऑब्जेक्ट के पाठ प्रतिनिधित्व को लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम तक।
WriteLine (अकेली) निर्दिष्ट एकल-सटीक फ़्लोटिंग-पॉइंट मान के पाठ प्रतिनिधित्व को लिखता है, इसके बाद मानक आउटपुट स्ट्रीम को वर्तमान लाइन टर्मिनेटर।
WriteLine (स्ट्रिंग) निर्दिष्ट स्ट्रिंग मान लिखता है, इसके बाद मानक आउटपुट स्ट्रीम में वर्तमान लाइन टर्मिनेटर, होता है।
WriteLine (UInt32) निर्दिष्ट 32-बिट अहस्ताक्षरित पूर्णांक मान का पाठ प्रतिनिधित्व लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम पर जाता है।
WriteLine (UInt64) निर्दिष्ट 64-बिट अहस्ताक्षरित पूर्णांक मान का पाठ प्रतिनिधित्व लिखता है, इसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम पर जाता है।
राइटलाइन (स्ट्रिंग, ऑब्जेक्ट) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में, वर्तमान लाइन टर्मिनेटर द्वारा निर्दिष्ट निर्दिष्ट ऑब्जेक्ट के पाठ प्रतिनिधित्व को लिखता है।
लिक्लाइन (स्ट्रिंग, वस्तु []) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में वर्तमान लाइन टर्मिनेटर द्वारा पीछा वस्तुओं की निर्दिष्ट सरणी का पाठ प्रतिनिधित्व लिखता है।
लिटललाइन (चार [], इंट ३, इंट ३) यूनिकोड वर्णों के निर्दिष्ट उपप्रकार को लिखते हैं, उसके बाद वर्तमान लाइन टर्मिनेटर, मानक आउटपुट स्ट्रीम को।
राइटलाइन (स्ट्रिंग, ऑब्जेक्ट, ऑब्जेक्ट) निर्दिष्ट ऑब्जेक्ट जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में वर्तमान लाइन टर्मिनेटर द्वारा निर्दिष्ट निर्दिष्ट वस्तुओं के पाठ प्रतिनिधित्व को लिखता है।
राइटलाइन (स्ट्रिंग, ऑब्जेक्ट, ऑब्जेक्ट, ऑब्जेक्ट) निर्दिष्ट ऑब्जेक्ट जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम में वर्तमान लाइन टर्मिनेटर द्वारा निर्दिष्ट निर्दिष्ट वस्तुओं के पाठ प्रतिनिधित्व को लिखता है।
राइटलाइन (स्ट्रिंग, ऑब्जेक्ट, ऑब्जेक्ट, ऑब्जेक्ट, ऑब्जेक्ट) निर्दिष्ट प्रारूप जानकारी का उपयोग करके मानक आउटपुट स्ट्रीम के लिए, वर्तमान लाइन टर्मिनेटर द्वारा निर्दिष्ट निर्दिष्ट वस्तुओं और चर-लंबाई पैरामीटर सूची के पाठ प्रतिनिधित्व को लिखता है।

निम्न उदाहरण कंसोल से पढ़ने और उसमें लिखने को प्रदर्शित करता है -

उदाहरण

open System
let main() =
   Console.Write("What's your name? ")
   let name = Console.ReadLine()
   Console.Write("Hello, {0}\n", name)
   Console.WriteLine(System.String.Format("Big Greetings from {0} and {1}", "TutorialsPoint", "Absoulte Classes"))
   Console.WriteLine(System.String.Format("|{0:yyyy-MMM-dd}|", System.DateTime.Now))
main()

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

What's your name? Kabir
Hello, Kabir
Big Greetings from TutorialsPoint and Absoulte Classes
|2015-Jan-05|

The System.IO नामस्थान

System.IO नाम स्थान में मूल I / O प्रदर्शन करने के लिए कई उपयोगी कक्षाएं हैं।

इसमें प्रकार या कक्षाएं शामिल हैं जो फ़ाइलों और डेटा धाराओं को पढ़ने और लिखने की अनुमति देती हैं और प्रकार जो मूल फ़ाइल और निर्देशिका समर्थन प्रदान करते हैं।

फाइल सिस्टम के साथ काम करने के लिए उपयोगी कक्षाएं -

  • System.IO.File वर्ग का उपयोग फ़ाइलों को बनाने, जोड़ने और हटाने के लिए किया जाता है।
  • System.IO.Directory वर्ग का उपयोग निर्देशिकाओं को बनाने, स्थानांतरित करने और हटाने के लिए किया जाता है।
  • System.IO.Path वर्ग स्ट्रिंग्स पर संचालन करता है, जो फ़ाइल पथों का प्रतिनिधित्व करता है।
  • System.IO.FileSystemWatcher वर्ग उपयोगकर्ताओं को परिवर्तनों के लिए एक निर्देशिका सुनने की अनुमति देता है।

धाराओं के साथ काम करने के लिए उपयोगी कक्षाएं (बाइट्स का क्रम) -

  • System.IO.StreamReader वर्ग का उपयोग किसी स्ट्रीम से वर्ण पढ़ने के लिए किया जाता है।
  • System.IO.StreamWriter क्लास का उपयोग किसी स्ट्रीम में वर्ण लिखने के लिए किया जाता है।
  • System.IO.MemoryStream क्लास बाइट्स की इन-मेमोरी स्ट्रीम बनाता है।

निम्न तालिका संक्षिप्त विवरण के साथ नाम स्थान में प्रदान की गई सभी कक्षाओं को दिखाती है -

कक्षा विवरण
BinaryReader एक विशिष्ट एन्कोडिंग में आदिम डेटा प्रकार को बाइनरी मान के रूप में पढ़ता है।
BinaryWriter एक धारा में बाइनरी में आदिम प्रकार लिखते हैं और एक विशिष्ट एन्कोडिंग में लेखन स्ट्रिंग का समर्थन करते हैं।
BufferedStream किसी अन्य स्ट्रीम पर संचालन पढ़ने और लिखने के लिए एक बफ़रिंग परत जोड़ता है।
निर्देशिका निर्देशिका और उपनिर्देशिकाओं के माध्यम से बनाने, आगे बढ़ने और गणना करने के लिए स्थैतिक तरीकों का प्रस्ताव है।
DirectoryInfo निर्देशिका और उपनिर्देशिकाओं के माध्यम से बनाने, स्थानांतरित करने और गणना करने के लिए उदाहरण के तरीकों का प्रस्ताव करता है।
DirectoryNotFoundException फ़ाइल या निर्देशिका के भाग के दौरान जो अपवाद फेंका गया है, वह नहीं मिल सकता है।
DriveInfo एक ड्राइव पर जानकारी तक पहुंच प्रदान करता है।
DriveNotFoundException वह अपवाद जो किसी ड्राइव या साझा को एक्सेस करने का प्रयास करते समय फेंका जाता है जो उपलब्ध नहीं है।
EndOfStreamException पढ़ते समय जो अपवाद फेंका जाता है, उसे एक धारा के अंत में लाने का प्रयास किया जाता है।
ErrorEventArgs FileSystemWatcher.Error इवेंट के लिए डेटा प्रदान करता है।
फ़ाइल एक एकल फ़ाइल के निर्माण, प्रतिलिपि बनाने, हटाने, स्थानांतरित करने और खोलने के लिए स्थिर तरीके प्रदान करता है, और फाइलस्ट्रीम ऑब्जेक्ट्स के निर्माण में सहायता करता है।
FileFormatException एक इनपुट फ़ाइल या डेटा स्ट्रीम जो एक निश्चित फ़ाइल प्रारूप विनिर्देश के अनुरूप माना जाता है, जब फेंक दिया जाता है तो अपवाद विकृत होता है।
फाइल के बारे में फाइलस्ट्रीम ऑब्जेक्ट्स के निर्माण में कॉपी, डिलीट, मूविंग, और फाइल खोलने और ऐड्स बनाने के लिए प्रॉपर्टीज और इंस्टेंस के तरीके उपलब्ध कराता है।
FileLoadException एक प्रबंधित असेंबली मिलने पर अपवाद को फेंक दिया जाता है, लेकिन लोड नहीं किया जा सकता है।
FileNotFoundException डिस्क पर मौजूद फ़ाइल का उपयोग करने का प्रयास विफल होने पर जो अपवाद दिया जाता है, वह विफल हो जाता है।
फ़ाइल धारा एक फ़ाइल के चारों ओर एक स्ट्रीम का विस्तार करता है, दोनों तुल्यकालिक और अतुल्यकालिक पढ़ने और लिखने के संचालन का समर्थन करता है।
FileSystemEventArgs निर्देशिका घटनाओं के लिए डेटा प्रदान करता है - परिवर्तित, निर्मित, हटाए गए।
FileSystemInfo FileInfo और DirectoryInfo ऑब्जेक्ट्स के लिए बेस क्लास प्रदान करता है।
FileSystemWatcher फ़ाइल सिस्टम परिवर्तन सूचनाओं को सुनता है और निर्देशिका, या निर्देशिका में फ़ाइल, परिवर्तन होने पर घटनाओं को उठाता है।
InternalBufferOverflowException आंतरिक बफ़र ओवरफ्लो होने पर अपवाद को फेंक दिया जाता है।
InvalidDataException डेटा स्ट्रीम अमान्य प्रारूप में होने पर अपवाद को फेंक दिया जाता है।
IODescriptionAttribute किसी घटना, एक्सटेंडर या प्रॉपर्टी को संदर्भित करते समय विवरण दृश्य डिजाइनर प्रदर्शित कर सकते हैं।
IOException I / O त्रुटि होने पर अपवाद को फेंक दिया जाता है।
MemoryStream एक स्ट्रीम बनाता है जिसका बैकिंग स्टोर मेमोरी है।
पथ स्ट्रिंग इंस्टेंस पर कार्रवाई करता है जिसमें फ़ाइल या निर्देशिका पथ जानकारी होती है। ये ऑपरेशन क्रॉस-प्लेटफॉर्म तरीके से किए जाते हैं।
PathTooLongException अपवाद जब एक पथ या फ़ाइल नाम सिस्टम-परिभाषित अधिकतम लंबाई से अधिक लंबा होता है।
PipeException एक नामित पाइप के भीतर कोई त्रुटि होने पर फेंक दें।
RenamedEventArgs नामांकित घटना के लिए डेटा प्रदान करता है।
धारा बाइट्स के अनुक्रम का एक सामान्य दृश्य प्रदान करता है। यह एक अमूर्त वर्ग है।
StreamReader एक TextReader को लागू करता है जो एक विशेष एन्कोडिंग में बाइट स्ट्रीम से वर्ण पढ़ता है।
StreamWriter किसी विशेष एन्कोडिंग में एक स्ट्रीम में वर्ण लिखने के लिए एक TextWriter लागू करता है। इस प्रकार के लिए .NET फ्रेमवर्क स्रोत कोड ब्राउज़ करने के लिए, संदर्भ स्रोत देखें।
StringReader एक TextReader को लागू करता है जो एक स्ट्रिंग से पढ़ता है।
StringWriter एक स्ट्रिंग को जानकारी लिखने के लिए एक TextWriter लागू करता है। जानकारी एक अंतर्निहित StringBuilder में संग्रहीत है।
TextReader एक पाठक का प्रतिनिधित्व करता है जो पात्रों की अनुक्रमिक श्रृंखला पढ़ सकता है।
TextWriter एक लेखक का प्रतिनिधित्व करता है जो पात्रों की अनुक्रमिक श्रृंखला लिख ​​सकता है। यह वर्ग अमूर्त है।
UnmanagedMemoryAccessor प्रबंधित कोड से स्मृति के अप्रबंधित ब्लॉकों तक यादृच्छिक पहुँच प्रदान करता है।
UnmanagedMemoryStream प्रबंधित कोड से स्मृति के अप्रबंधित ब्लॉकों तक पहुंच प्रदान करता है।
WindowsRuntimeStorageExtensions Windows स्टोर एप्लिकेशन विकसित करते समय Windows रनटाइम में IStorageFile और IStorageFolder इंटरफ़ेस के लिए विस्तार विधियाँ शामिल हैं।
WindowsRuntimeStreamExtensions विंडोज रनटाइम में स्ट्रीम और प्रबंधित स्ट्रीम में स्ट्रीम के बीच कनवर्ट करने के लिए विस्तार विधियाँ शामिल हैं।

उदाहरण

निम्न उदाहरण test.txt नामक एक फ़ाइल बनाता है, वहाँ एक संदेश लिखता है, फ़ाइल से पाठ पढ़ता है और इसे कंसोल पर प्रिंट करता है।

Note - ऐसा करने के लिए आवश्यक कोड की मात्रा आश्चर्यजनक रूप से कम है!

open System.IO // Name spaces can be opened just as modules
File.WriteAllText("test.txt", "Hello There\n Welcome to:\n Tutorials Point")
let msg = File.ReadAllText("test.txt")
printfn "%s" msg

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

Hello There
Welcome to:
Tutorials Point

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

आप डेटा प्रकारों के लिए स्थानापन्न मापदंडों के साथ वर्ग या विधि के लिए विनिर्देशों को लिखते हैं। जब कंपाइलर कक्षा के लिए एक कंस्ट्रक्टर का सामना करता है या विधि के लिए एक फ़ंक्शन कॉल करता है, तो यह विशिष्ट डेटा प्रकार को संभालने के लिए कोड उत्पन्न करता है।

F # में, फंक्शन वैल्यू, मेथड, प्रॉपर्टी, और एग्रीगेट टाइप जैसे कि क्लासेस, रिकॉर्ड्स, और भेदभाव किए गए यूनियनों जेनेरिक हो सकते हैं।

सामान्य निर्माण में कम से कम एक प्रकार का पैरामीटर होता है। जेनेरिक फ़ंक्शंस और प्रकार आपको कोड लिखने में सक्षम करते हैं जो प्रत्येक प्रकार के लिए कोड को दोहराए बिना विभिन्न प्रकार के साथ काम करता है।

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

एक सामान्य निर्माण लिखने के लिए सिंटैक्स इस प्रकार है -

// Explicitly generic function.
let function-name<type-parameters> parameter-list =
   function-body

// Explicitly generic method.
[ static ] member object-identifer.method-name<type-parameters> parameter-list [ return-type ] =
   method-body

// Explicitly generic class, record, interface, structure,
// or discriminated union.
type type-name<type-parameters> type-definition

उदाहरण

(* Generic Function *)
let printFunc<'T> x y =
   printfn "%A, %A" x y

printFunc<float> 10.0 20.0

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

10.0, 20.0

आप एकल उद्धरण चिह्न सिंटैक्स का उपयोग करके एक फ़ंक्शन सामान्य भी बना सकते हैं -

(* Generic Function *)
let printFunction (x: 'a) (y: 'a) =
   printfn "%A %A" x y

printFunction 10.0 20.0

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

10.0 20.0

कृपया ध्यान दें कि जब आप जेनेरिक फ़ंक्शंस या विधियों का उपयोग करते हैं, तो आपको टाइप तर्क निर्दिष्ट करने की आवश्यकता नहीं हो सकती है। हालाँकि, अस्पष्टता के मामले में, आप कोण कोष्ठक में टाइप तर्क दे सकते हैं जैसा कि हमने पहले उदाहरण में किया था।

यदि आपके पास एक से अधिक प्रकार हैं, तो आप कई प्रकार के तर्क अल्पविराम से अलग करते हैं।

सामान्य वर्ग

जेनेरिक कार्यों की तरह, आप जेनेरिक कक्षाएं भी लिख सकते हैं। निम्न उदाहरण यह प्रदर्शित करता है -

type genericClass<'a> (x: 'a) =
   do printfn "%A" x

let gr = new genericClass<string>("zara")
let gs = genericClass( seq { for i in 1 .. 10 -> (i, i*i) } )

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

"zara"
seq [(1, 1); (2, 4); (3, 9); (4, 16); ...]

एक प्रतिनिधि एक संदर्भ प्रकार चर है जो एक विधि के संदर्भ को रखता है। संदर्भ को रनटाइम में बदला जा सकता है। F # डेलीगेट C या C ++ में, फंक्शनर्स के समान हैं।

घोषणा पत्र

डेलिगेट घोषणा प्रतिनिधि द्वारा संदर्भित तरीकों को निर्धारित करती है। एक प्रतिनिधि एक विधि का उल्लेख कर सकता है, जिसमें प्रतिनिधि के रूप में एक ही हस्ताक्षर हो।

प्रतिनिधि घोषणा के लिए सिंटैक्स है -

type delegate-typename = delegate of type1 -> type2

उदाहरण के लिए, प्रतिनिधियों पर विचार करें -

// Delegate1 works with tuple arguments.
type Delegate1 = delegate of (int * int) -> int
// Delegate2 works with curried arguments.
type Delegate2 = delegate of int * int -> int

दोनों प्रतिनिधियों किसी भी विधि दो है कि संदर्भित करने के लिए इस्तेमाल किया जा सकता पूर्णांक मापदंडों और एक रिटर्न पूर्णांक प्रकार चर।

वाक्य रचना में -

  • type1 तर्क प्रकार का प्रतिनिधित्व करता है।

  • type2 वापसी प्रकार का प्रतिनिधित्व करता है।

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

  • तर्क प्रकार स्वचालित रूप से कर रहे हैं।

  • प्रतिनिधि फ़ंक्शन मानों और स्थिर या आवृत्ति विधियों से जुड़े हो सकते हैं।

  • एफ # फ़ंक्शन मानों को सीधे निर्माणकर्ताओं को सौंपने के तर्क के रूप में पारित किया जा सकता है।

  • एक स्थिर विधि के लिए प्रतिनिधि को वर्ग और विधि के नाम का उपयोग करके बुलाया जाता है। एक आवृत्ति विधि के लिए, ऑब्जेक्ट आवृत्ति और विधि का नाम उपयोग किया जाता है।

  • प्रतिनिधि प्रकार पर आह्वान विधि एन्कैप्सुलेटेड फ़ंक्शन को कॉल करती है।

  • इसके अलावा, प्रतिनिधियों को कोष्ठकों के बिना इनवोक विधि के नाम को संदर्भित करके फ़ंक्शन मान के रूप में पारित किया जा सकता है।

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

उदाहरण

type Myclass() =
   static member add(a : int, b : int) =
      a + b
   static member sub (a : int) (b : int) =
      a - b
   member x.Add(a : int, b : int) =
      a + b
   member x.Sub(a : int) (b : int) =
      a - b

// Delegate1 works with tuple arguments.
type Delegate1 = delegate of (int * int) -> int
// Delegate2 works with curried arguments.
type Delegate2 = delegate of int * int -> int

let InvokeDelegate1 (dlg : Delegate1) (a : int) (b: int) =
   dlg.Invoke(a, b)
let InvokeDelegate2 (dlg : Delegate2) (a : int) (b: int) =
   dlg.Invoke(a, b)

// For static methods, use the class name, the dot operator, and the
// name of the static method.
let del1 : Delegate1 = new Delegate1( Myclass.add )
let del2 : Delegate2 = new Delegate2( Myclass.sub )

let mc = Myclass()
// For instance methods, use the instance value name, the dot operator, and the instance method name.

let del3 : Delegate1 = new Delegate1( mc.Add )
let del4 : Delegate2 = new Delegate2( mc.Sub )

for (a, b) in [ (400, 200); (100, 45) ] do
   printfn "%d + %d = %d" a b (InvokeDelegate1 del1 a b)
   printfn "%d - %d = %d" a b (InvokeDelegate2 del2 a b)
   printfn "%d + %d = %d" a b (InvokeDelegate1 del3 a b)
   printfn "%d - %d = %d" a b (InvokeDelegate2 del4 a b)

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

400 + 200 = 600
400 - 200 = 200
400 + 200 = 600
400 - 200 = 200
100 + 45 = 145
100 - 45 = 55
100 + 45 = 145
100 - 45 = 55

एक गणना नामांकित पूर्णांक स्थिरांक का एक सेट है।

एफ # में, enumerations, के रूप में भी जाना जाता है enums,अभिन्न प्रकार हैं जहां लेबल को मानों का सबसेट सौंपा गया है। कोड को अधिक पठनीय और बनाए रखने के लिए आप उन्हें शाब्दिक के स्थान पर उपयोग कर सकते हैं।

घोषणाएँ घोषित करना

एन्यूमरेशन घोषित करने का सामान्य सिंटैक्स है -

type enum-name =
   | value1 = integer-literal1
   | value2 = integer-literal2
...

निम्नलिखित उदाहरण गणना के उपयोग को दर्शाता है -

उदाहरण

// Declaration of an enumeration.
type Days =
   | Sun = 0
   | Mon = 1
   | Tues = 2
   | Wed = 3
   | Thurs = 4
   | Fri = 5
   | Sat = 6

// Use of an enumeration.
let weekend1 : Days = Days.Sat
let weekend2 : Days = Days.Sun
let weekDay1 : Days = Days.Mon

printfn "Monday: %A" weekDay1
printfn "Saturday: %A" weekend1
printfn "Sunday: %A" weekend2

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

Monday: Mon
Saturday: Sat
Sunday: Sun

पैटर्न मिलान आपको "तार्किक संरचना या संरचनाओं के साथ डेटा की तुलना करने, घटक भागों में डेटा विघटित करने या विभिन्न तरीकों से डेटा से जानकारी निकालने" की अनुमति देता है।

अन्य शब्दों में, यह शर्तों की एक श्रृंखला के खिलाफ डेटा के परीक्षण का एक अधिक लचीला और शक्तिशाली तरीका प्रदान करता है और मिले हुए शर्त के आधार पर कुछ संगणनाएं करता है।

वैचारिक रूप से, यह अगर ... की एक श्रृंखला की तरह है, तो कथन।

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

उच्च स्तर की शर्तों में, पैटर्न मिलान F # में इस सिंटैक्स का अनुसरण करता है -

match expr with
| pat1 - result1
| pat2 -> result2
| pat3 when expr2 -> result3
| _ -> defaultResult

कहाँ पे,

  • प्रत्येक | प्रतीक एक शर्त को परिभाषित करता है।
  • -> प्रतीक का अर्थ है "यदि स्थिति सत्य है, तो इस मान को लौटाएं ..."।
  • _ प्रतीक डिफ़ॉल्ट पैटर्न प्रदान करता है, जिसका अर्थ है कि यह वाइल्डकार्ड की तरह अन्य सभी चीजों से मेल खाता है।

उदाहरण 1

निम्नलिखित उदाहरण, पैटर्न मिलान वाक्यविन्यास का उपयोग करके फाइबोनैचि संख्याओं की गणना करता है -

let rec fib n =
   match n with
   | 0 -> 0
   | 1 -> 1
   | _ -> fib (n - 1) + fib (n - 2)
for i = 1 to 10 do
   printfn "Fibonacci %d: %d" i (fib i)

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

Fibonacci 1: 1
Fibonacci 2: 1
Fibonacci 3: 2
Fibonacci 4: 3
Fibonacci 5: 5
Fibonacci 6: 8
Fibonacci 7: 13
Fibonacci 8: 21
Fibonacci 9: 34
Fibonacci 10: 55

आप कई स्थितियों में एक साथ श्रृंखला भी बना सकते हैं, जो समान मान लौटाते हैं। उदाहरण के लिए -

उदाहरण 2

let printSeason month =
   match month with
   | "December" | "January" | "February" -> printfn "Winter"
   | "March" | "April" -> printfn "Spring"
   | "May" | "June" -> printfn "Summer"
   | "July" | "August" -> printfn "Rainy"
   | "September" | "October" | "November" -> printfn "Autumn"
   | _ -> printfn "Season depends on month!"

printSeason "February"
printSeason "April"
printSeason "November"
printSeason "July"

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

Winter
Spring
Autumn
Rainy

पैटर्न मिलान कार्य

F # आपको पैटर्न मिलान कार्यों को लिखने की अनुमति देता है function कीवर्ड -

let getRate = function
   | "potato" -> 10.00
   | "brinjal" -> 20.50
   | "cauliflower" -> 21.00
   | "cabbage" -> 8.75
   | "carrot" -> 15.00
   | _ -> nan (* nan is a special value meaning "not a number" *)

printfn "%g"(getRate "potato")
printfn "%g"(getRate "brinjal")
printfn "%g"(getRate "cauliflower")
printfn "%g"(getRate "cabbage")
printfn "%g"(getRate "carrot")

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

10
20.5
21
8.75
15

पैटर्न में फिल्टर या गार्ड जोड़ना

आप का उपयोग करके पैटर्न में फ़िल्टर या गार्ड जोड़ सकते हैं when कीवर्ड।

उदाहरण 1

let sign = function
   | 0 -> 0
   | x when x < 0 -> -1
   | x when x > 0 -> 1

printfn "%d" (sign -20)
printfn "%d" (sign 20)
printfn "%d" (sign 0)

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

-1
1
0

उदाहरण 2

let compareInt x =
   match x with
   | (var1, var2) when var1 > var2 -> printfn "%d is greater than %d" var1 var2
   | (var1, var2) when var1 < var2 -> printfn "%d is less than %d" var1 var2
   | (var1, var2) -> printfn "%d equals %d" var1 var2

compareInt (11,25)
compareInt (72, 10)
compareInt (0, 0)

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

11 is less than 25
72 is greater than 10
0 equals 0

ट्यूपल्स के साथ पैटर्न मिलान

निम्न उदाहरण ट्यूपल्स के साथ मेल खाते हुए पैटर्न को दर्शाता है -

let greeting (name, subject) =
   match (name, subject) with
   | ("Zara", _) -> "Hello, Zara"
   | (name, "English") -> "Hello, " + name + " from the department of English"
   | (name, _) when subject.StartsWith("Comp") -> "Hello, " + name + " from the department of Computer Sc."
   | (_, "Accounts and Finance") -> "Welcome to the department of Accounts and Finance!"
   | _ -> "You are not registered into the system"

printfn "%s" (greeting ("Zara", "English"))
printfn "%s" (greeting ("Raman", "Computer Science"))
printfn "%s" (greeting ("Ravi", "Mathematics"))

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

Hello, Zara
Hello, Raman from the department of Computer Sc.
You are not registered into the system

रिकॉर्ड्स के साथ पैटर्न मिलान

निम्न उदाहरण अभिलेखों से मेल खाते पैटर्न को प्रदर्शित करता है -

type Point = { x: float; y: float }
let evaluatePoint (point: Point) =
   match point with
   | { x = 0.0; y = 0.0 } -> printfn "Point is at the origin."
   | { x = xVal; y = 0.0 } -> printfn "Point is on the x-axis. Value is %f." xVal
   | { x = 0.0; y = yVal } -> printfn "Point is on the y-axis. Value is %f." yVal
   | { x = xVal; y = yVal } -> printfn "Point is at (%f, %f)." xVal yVal

evaluatePoint { x = 0.0; y = 0.0 }
evaluatePoint { x = 10.0; y = 0.0 }
evaluatePoint { x = 0.0; y = 10.0 }
evaluatePoint { x = 10.0; y = 10.0 }

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

Point is at the origin.
Point is on the x-axis. Value is 10.000000.
Point is on the y-axis. Value is 10.000000.
Point is at (10.000000, 10.000000).

एक अपवाद एक समस्या है जो एक कार्यक्रम के निष्पादन के दौरान उत्पन्न होती है। एक एफ # अपवाद एक असाधारण परिस्थिति की प्रतिक्रिया है जो किसी कार्यक्रम को चलाने के दौरान उत्पन्न होती है, जैसे कि शून्य से विभाजित करने का प्रयास।

अपवाद प्रोग्राम के एक भाग से दूसरे में नियंत्रण स्थानांतरित करने का एक तरीका प्रदान करते हैं। F # अपवाद हैंडलिंग निम्नलिखित निर्माण प्रदान करता है -

निर्माण विवरण
expr बढ़ा दिए गए अपवाद को उठाता है।
फेल होने के बावजूद उठाता है System.Exception अपवाद।
नियमों के साथ विस्तार करने का प्रयास करें पैटर्न नियमों से मेल खाती अभिव्यक्तियाँ।
समाप्ति समाप्ति का प्रयास करें निष्पादन finally अभिकलन सफल होने पर और अपवाद को उठाए जाने पर दोनों अभिव्यक्ति।
| : ArgumentException दिए गए .NET अपवाद प्रकार से मेल खाने वाला नियम।
| : ई के रूप में तर्क एक नियम। दिए गए .NET अपवाद प्रकार से मेल खाते हुए, नाम को बांधते हुए e अपवाद ऑब्जेक्ट मान के लिए।
| विफलता (संदेश) → expr दिए गए डेटा ले जाने वाले F # अपवाद से मेल खाने वाला नियम।
| exn → एक्सप्र एक नियम जो किसी अपवाद को मिलाता है, नाम को बांधता है exn अपवाद ऑब्जेक्ट मान के लिए।
| exn जब expr → expr एक नियम दिए गए शर्त के तहत अपवाद से मेल खाता है, नाम को बांधता है exn अपवाद ऑब्जेक्ट मान के लिए।

आइए हम अपवाद हैंडलिंग के मूल सिंटैक्स के साथ शुरू करें।

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

F # अपवाद हैंडलिंग ब्लॉक के लिए मूल सिंटैक्स है -

exception exception-type of argument-type

कहाँ पे,

  • exception-type एक नए F # अपवाद प्रकार का नाम है।

  • argument-type एक तर्क के प्रकार का प्रतिनिधित्व करता है जिसे आपूर्ति की जा सकती है जब आप इस प्रकार का अपवाद उठाते हैं।

  • तर्क-प्रकार के लिए टपल प्रकार का उपयोग करके कई तर्क निर्दिष्ट किए जा सकते हैं।

try...with अभिव्यक्ति का उपयोग F # भाषा में अपवाद हैंडलिंग के लिए किया जाता है।

अभिव्यक्ति के लिए ... के लिए सिंटैक्स है -

try
   expression1
with
   | pattern1 -> expression2
   | pattern2 -> expression3
...

try...finally अभिव्यक्ति आपको क्लीन-अप कोड निष्पादित करने की अनुमति देती है, भले ही कोड का एक ब्लॉक एक अपवाद फेंकता हो।

कोशिश के लिए सिंटैक्स ... आखिरकार अभिव्यक्ति है -

try
   expression1
finally
   expression2

raiseफ़ंक्शन का उपयोग यह इंगित करने के लिए किया जाता है कि कोई त्रुटि या असाधारण स्थिति उत्पन्न हुई है। यह अपवाद ऑब्जेक्ट में त्रुटि के बारे में जानकारी भी कैप्चर करता है।

वृद्धि समारोह के लिए सिंटैक्स है -

raise (expression)

failwith फ़ंक्शन एक F # अपवाद उत्पन्न करता है।

विफलता फ़ंक्शन के लिए सिंटैक्स है -

failwith error-message-string

invalidArg फ़ंक्शन एक तर्क अपवाद उत्पन्न करता है।

invalidArg parameter-name error-message-string

अपवाद हैंडलिंग का उदाहरण

उदाहरण 1

निम्नलिखित कार्यक्रम ब्लॉक के साथ एक साधारण प्रयास के साथ बुनियादी अपवाद को दर्शाता है -

let divisionprog x y =
   try
      Some (x / y)
   with
      | :? System.DivideByZeroException -> printfn "Division by zero!"; None

let result1 = divisionprog 100 0

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

Division by zero!

उदाहरण 2

एफ # एक प्रदान करता है exceptionअपवाद घोषित करने के लिए टाइप करें। आप फ़िल्टर में सीधे एक अपवाद प्रकार का उपयोग कर सकते हैंtry...with अभिव्यक्ति।

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

exception Error1 of string
// Using a tuple type as the argument type.
exception Error2 of string * int

let myfunction x y =
   try
      if x = y then raise (Error1("Equal Number Error"))
      else raise (Error2("Error Not detected", 100))
   with
      | Error1(str) -> printfn "Error1 %s" str
      | Error2(str, i) -> printfn "Error2 %s %d" str i
myfunction 20 10
myfunction 5 5

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

Error2 Error Not detected 100
Error1 Equal Number Error

उदाहरण 3

निम्न उदाहरण नेस्टेड अपवाद हैंडलिंग को दर्शाता है -

exception InnerError of string
exception OuterError of string

let func1 x y =
   try
      try
         if x = y then raise (InnerError("inner error"))
         else raise (OuterError("outer error"))
      with
         | InnerError(str) -> printfn "Error:%s" str
   finally
      printfn "From the finally block."

let func2 x y =
   try
      func1 x y
   with
      | OuterError(str) -> printfn "Error: %s" str

func2 100 150
func2 100 100
func2 100 120

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

From the finally block.
Error: outer error
Error:inner error
From the finally block.
From the finally block.
Error: outer error

उदाहरण 4

निम्न कार्य दर्शाता है failwith कार्य -

let divisionFunc x y =
   if (y = 0) then failwith "Divisor cannot be zero."
   else
      x / y

let trydivisionFunc x y =
   try
      divisionFunc x y
   with
      | Failure(msg) -> printfn "%s" msg; 0

let result1 = trydivisionFunc 100 0
let result2 = trydivisionFunc 100 4
printfn "%A" result1
printfn "%A" result2

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

Divisor cannot be zero.
0
25

उदाहरण 5

invalidArgफ़ंक्शन एक तर्क अपवाद उत्पन्न करता है। निम्नलिखित कार्यक्रम यह प्रदर्शित करता है -

let days = [| "Sunday"; "Monday"; "Tuesday"; "Wednesday"; "Thursday"; "Friday"; "Saturday" |]
let findDay day =
   if (day > 7 || day < 1)
      then invalidArg "day" (sprintf "You have entered %d." day)
   days.[day - 1]

printfn "%s" (findDay 1)
printfn "%s" (findDay 5)
printfn "%s" (findDay 9)

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

Sunday
Thursday
Unhandled Exception:
System.ArgumentException: You have entered 9.
…

फ़ाइल और चर के बारे में कुछ अन्य जानकारी जो सिस्टम में त्रुटि है, सिस्टम के आधार पर भी प्रदर्शित की जाएगी।

वर्ग वे प्रकार हैं जो उन वस्तुओं का प्रतिनिधित्व करते हैं जिनमें गुण, विधियाँ और घटनाएँ हो सकती हैं। 'उनका उपयोग अनुप्रयोगों में क्रियाओं, प्रक्रियाओं और किसी भी वैचारिक संस्थाओं के मॉडल के लिए किया जाता है।'

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

एक वर्ग प्रकार को परिभाषित करने के लिए सिंटैक्स निम्नानुसार है -

// 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

कृपया ग्रीटिंग्स वर्ग के लिए स्व-पहचानकर्ता जीआर के उपयोग पर ध्यान दें ।

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

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

एक संरचना को परिभाषित करने के लिए सिंटैक्स इस प्रकार है -

[ attributes ]
type [accessibility-modifier] type-name =
   struct
      type-definition-elements
   end
// or
[ attributes ]
[<StructAttribute>]
type [accessibility-modifier] type-name =
   type-definition-elements

दो वाक्यविन्यास हैं। पहला सिंटैक्स ज्यादातर उपयोग किया जाता है, क्योंकि, यदि आप उपयोग करते हैंstruct तथा end कीवर्ड, आप छोड़ सकते हैं StructAttribute विशेषता।

संरचना परिभाषा तत्व प्रदान करते हैं -

  • सदस्य घोषणाएँ और परिभाषाएँ।
  • कंस्ट्रक्टर और उत्परिवर्ती और अपरिवर्तनीय क्षेत्र।
  • सदस्य और इंटरफ़ेस कार्यान्वयन।

वर्गों के विपरीत, संरचनाओं को विरासत में नहीं दिया जा सकता है और इसमें बाइंडिंग नहीं होने दी जा सकती है। चूंकि, संरचनाओं में बाइंडिंग नहीं है; आपको संरचनाओं का उपयोग करके क्षेत्रों की घोषणा करनी चाहिएval कीवर्ड।

जब आप किसी फ़ील्ड और उसके प्रकार का उपयोग करते हैं valकीवर्ड, आप फ़ील्ड मान को इनिशियलाइज़ नहीं कर सकते हैं, इसके बजाय वे शून्य या शून्य के लिए इनिशियलाइज़ किए जाते हैं। तो एक संरचना का एक निहित निर्माता होने के लिए, एval घोषणाओं के साथ टिप्पणी की जानी चाहिए DefaultValue विशेषता।

उदाहरण

निम्न प्रोग्राम एक निर्माता के साथ एक लाइन संरचना बनाता है। कार्यक्रम संरचना का उपयोग कर एक पंक्ति की लंबाई की गणना करता है -

type Line = struct
   val X1 : float
   val Y1 : float
   val X2 : float
   val Y2 : float

   new (x1, y1, x2, y2) =
      {X1 = x1; Y1 = y1; X2 = x2; Y2 = y2;}
end
let calcLength(a : Line)=
   let sqr a = a * a
   sqrt(sqr(a.X1 - a.X2) + sqr(a.Y1 - a.Y2) )

let aLine = new Line(1.0, 1.0, 4.0, 5.0)
let length = calcLength aLine
printfn "Length of the Line: %g " length

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

Length of the Line: 5

आप F # में उपलब्ध अधिकांश अंतर्निहित ऑपरेटरों को फिर से परिभाषित या अधिभारित कर सकते हैं। इस प्रकार एक प्रोग्रामर ऑपरेटर को उपयोगकर्ता-परिभाषित प्रकारों के साथ भी उपयोग कर सकता है।

ऑपरेटर विशेष नामों के साथ कार्य करते हैं, जो कोष्ठक में संलग्न हैं। उन्हें स्थिर वर्ग के सदस्यों के रूप में परिभाषित किया जाना चाहिए। किसी भी अन्य फ़ंक्शन की तरह, एक अतिभारित ऑपरेटर के पास एक वापसी प्रकार और एक पैरामीटर सूची है।

निम्न उदाहरण, जटिल संख्याओं पर + ऑपरेटर दिखाता है -

//overloading + operator
static member (+) (a : Complex, b: Complex) =
Complex(a.x + b.x, a.y + b.y)

उपरोक्त फ़ंक्शन उपयोगकर्ता-परिभाषित क्लास कॉम्प्लेक्स के लिए अतिरिक्त ऑपरेटर (+) को लागू करता है। यह दो ऑब्जेक्ट्स की विशेषताओं को जोड़ता है और परिणामी कॉम्प्लेक्स ऑब्जेक्ट को लौटाता है।

ऑपरेटर ओवरलोडिंग का कार्यान्वयन

निम्नलिखित कार्यक्रम पूरा कार्यान्वयन दिखाता है -

//implementing a complex class with +, and - operators
//overloaded
type Complex(x: float, y : float) =
   member this.x = x
   member this.y = y
   //overloading + operator
   static member (+) (a : Complex, b: Complex) =
      Complex(a.x + b.x, a.y + b.y)

   //overloading - operator
   static member (-) (a : Complex, b: Complex) =
      Complex(a.x - b.x, a.y - b.y)

   // overriding the ToString method
   override this.ToString() =
      this.x.ToString() + " " + this.y.ToString()

//Creating two complex numbers
let c1 = Complex(7.0, 5.0)
let c2 = Complex(4.2, 3.1)

// addition and subtraction using the
//overloaded operators
let c3 = c1 + c2
let c4 = c1 - c2

//printing the complex numbers
printfn "%s" (c1.ToString())
printfn "%s" (c2.ToString())
printfn "%s" (c3.ToString())
printfn "%s" (c4.ToString())

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

7 5
4.2 3.1
11.2 8.1
2.8 1.9

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

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

विरासत का विचार आईएस-ए संबंध को लागू करता है। उदाहरण के लिए, स्तनपायी 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.

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

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

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

// 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

इवेंट कक्षाओं को एक दूसरे के बीच संदेश भेजने और प्राप्त करने की अनुमति देते हैं।

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

ऑब्जेक्ट्स एक दूसरे के साथ सिंक्रोनस मैसेज पासिंग के जरिए संवाद करते हैं।

कार्यक्रम अन्य कार्यों से जुड़े होते हैं; ऑब्जेक्ट रजिस्टर होते हैंcallback किसी ईवेंट के फ़ंक्शंस, और इन कॉलबैक को तब निष्पादित किया जाता है जब (और यदि) ईवेंट को किसी ऑब्जेक्ट द्वारा ट्रिगर किया जाता है।

इवेंट क्लास और इवेंट मॉड्यूल

Control.Event <'T> क्लास एक ऑब्जर्वेबल ऑब्जेक्ट या ईवेंट बनाने में मदद करता है।

घटनाओं के साथ काम करने के लिए इसके निम्न उदाहरण सदस्य हैं -

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

नियंत्रण.ईवेंट मॉड्यूल इवेंट स्ट्रीम प्रबंधित करने के लिए कार्य प्रदान करता है -

मूल्य विवरण
जोड़ें: ('T → यूनिट) → इवेंट <' Del, 'T> → यूनिट दिए गए फ़ंक्शन को ट्रिगर होने पर हर बार दिए गए फ़ंक्शन को चलाता है।
चुनें: ('T →' U विकल्प) → IEvent <'Del,' T> → IEvent <'U> एक नया ईवेंट लौटाता है जो मूल ईवेंट से संदेशों के चयन पर फायर करता है। चयन फ़ंक्शन एक वैकल्पिक नए संदेश के लिए एक मूल संदेश लेता है।
फ़िल्टर: ('T → बूल) → IEvent <' Del, 'T> → IEvent <' T> एक नया ईवेंट देता है जो मूल ईवेंट को सुनता है और परिणामी ईवेंट को तभी ट्रिगर करता है जब इवेंट का तर्क दिए गए फ़ंक्शन को पास करता है।
नक्शा: ('T →' U) → IEvent <'Del,' T> → IEvent <'U> एक नया ईवेंट देता है जो दिए गए फ़ंक्शन द्वारा परिवर्तित मानों को पार करता है।
मर्ज: IEvent <'Del1,' T> → IEvent <'Del2,' T> → IEvent <'T> जब इनपुट इवेंट्स में से किसी एक में आग लगने की घटना होती है।
जोड़ीदार: IEvent <'Del,' T> → IEvent <'T *' T> एक नया ईवेंट देता है जो इनपुट ईवेंट के दूसरे और बाद के ट्रिगर पर ट्रिगर होता है। Nth इनपुट ईवेंट का ट्रिगर तर्क से पास करता है N-1th तथा Nthएक जोड़ी के रूप में ट्रिगर। तक तर्क पहुंचाN-1th ट्रिगर को छिपी हुई आंतरिक स्थिति में आयोजित किया जाता है Nth ट्रिगरिंग होती है।
विभाजन: ('T → बूल) → IEvent <' Del, 'T> → IEvent <' T> * IEvent </ b> एक नया ईवेंट लौटाता है, जो मूल ईवेंट को सुनता है और यदि घटना के तर्क के लिए विधेय का आवेदन सही है, और दूसरा ईवेंट यदि वह गलत लौटा है तो पहली परिणामी घटना को ट्रिगर करता है।
स्कैन: ('U →' T → 'U) →' U → IEvent <'Del,' T> → IEvent </ u> इनपुट इवेंट पर ट्रिगर किए गए क्रमिक मानों के लिए दिए गए संचय फ़ंक्शन को लागू करने के परिणामों से मिलकर एक नई घटना देता है। आंतरिक स्थिति का एक आइटम राज्य पैरामीटर के वर्तमान मूल्य को रिकॉर्ड करता है। आंतरिक राज्य संचय समारोह के निष्पादन के दौरान बंद नहीं किया जाता है, इसलिए ध्यान रखा जाना चाहिए कि इनपुट IEvent एक साथ कई थ्रेड द्वारा ट्रिगर नहीं किया गया है।
विभाजन: ('T → चॉइस <' U1, 'U2>) → IEvent <' Del, 'T> → IEvent <' U1> * IEvent <'U2> एक नया ईवेंट लौटाता है जो मूल ईवेंट को सुनता है और यदि फ़ंक्शन तर्क के लिए फ़ंक्शन का आवेदन एक च्वाइस 1 ओएफ 2, और दूसरा ईवेंट च्वाइस 2 ओएफ 2 लौटाता है, तो यह पहली परिणामी घटना को ट्रिगर करता है।

घटनाएँ बनाना

ईवेंट का निर्माण और उपयोग किया जाता है Eventकक्षा। ईवेंट कंस्ट्रक्टर का उपयोग ईवेंट बनाने के लिए किया जाता है।

उदाहरण

type Worker(name : string, shift : string) =
   let mutable _name = name;
   let mutable _shift = shift;
   let nameChanged = new Event<unit>() (* creates event *)
   let shiftChanged = new Event<unit>() (* creates event *)

   member this.Name
      with get() = _name
      and set(value) = _name <- value

   member this.Shift
      with get() = _shift
      and set(value) = _shift <- value

इसके बाद आपको सार्वजनिक सदस्य के रूप में नामांकित फ़ील्ड को उजागर करने की आवश्यकता है, ताकि सुनने वाले उस घटना पर हुक कर सकें जिसके लिए आप उपयोग करते हैं Publish घटना की संपत्ति -

type Worker(name : string, shift : string) =
   let mutable _name = name;
   let mutable _shift = shift;

   let nameChanged = new Event<unit>() (* creates event *)
   let shiftChanged = new Event<unit>() (* creates event *)

   member this.NameChanged = nameChanged.Publish (* exposed event handler *)
   member this.ShiftChanged = shiftChanged.Publish (* exposed event handler *)

   member this.Name
      with get() = _name
      and set(value) = _name <- value
      nameChanged.Trigger() (* invokes event handler *)

   member this.Shift
      with get() = _shift
      and set(value) = _shift <- value
   shiftChanged.Trigger() (* invokes event handler *)

इसके बाद, आप ईवेंट हैंडलर में कॉलबैक जोड़ते हैं। प्रत्येक ईवेंट हैंडलर में IEvent <'T> टाइप होता है, जो कई तरीके प्रदान करता है -

तरीका विवरण
वैल ऐड: इवेंट :( 'टी → यूनिट) → यूनिट घटना के लिए एक श्रोता समारोह जोड़ता है। घटना के निकाल दिए जाने पर श्रोता को आमंत्रित किया जाएगा।
वैल एडहैंडलर: 'डेल → यूनिट घटना के लिए एक हैंडलर प्रतिनिधि ऑब्जेक्ट जोड़ता है। एक हैंडलर को बाद में RemoveHandler का उपयोग करके हटाया जा सकता है। घटना के निकाल दिए जाने पर श्रोता को आमंत्रित किया जाएगा।
वैल रिमांडहैंडलर: 'डेल → यूनिट किसी ईवेंट श्रोता स्टोर से एक श्रोता प्रतिनिधि को निकालता है।

निम्नलिखित अनुभाग एक पूर्ण उदाहरण प्रदान करता है।

उदाहरण

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

type Worker(name : string, shift : string) =
   let mutable _name = name;
   let mutable _shift = shift;

   let nameChanged = new Event<unit>() (* creates event *)
   let shiftChanged = new Event<unit>() (* creates event *)

   member this.NameChanged = nameChanged.Publish (* exposed event handler *)
   member this.ShiftChanged = shiftChanged.Publish (* exposed event handler *)

   member this.Name
      with get() = _name
      and set(value) = 
         _name <- value
         nameChanged.Trigger() (* invokes event handler *)

   member this.Shift
      with get() = _shift
      and set(value) = 
         _shift <- value
         shiftChanged.Trigger() (* invokes event handler *)

let wk = new Worker("Wilson", "Evening")
wk.NameChanged.Add(fun () -> printfn "Worker changed name! New name: %s" wk.Name)
wk.Name <- "William"
wk.NameChanged.Add(fun () -> printfn "-- Another handler attached to NameChanged!")
wk.Name <- "Bill"

wk.ShiftChanged.Add(fun () -> printfn "Worker changed shift! New shift: %s" wk.Shift)
wk.Shift <- "Morning"
wk.ShiftChanged.Add(fun () -> printfn "-- Another handler attached to ShiftChanged!")
wk.Shift <- "Night"

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

Worker changed name! New name: William
Worker changed name! New name: Bill
-- Another handler attached to NameChanged!
Worker changed shift! New shift: Morning
Worker changed shift! New shift: Night
-- Another handler attached to ShiftChanged!

MSDN लाइब्रेरी के अनुसार, F # मॉड्यूल, बाइंडिंग के प्रकारों, मानों, फ़ंक्शन मानों और कोड जैसे F # कोड निर्माणों का एक समूह है। यह एक सामान्य भाषा रनटाइम (CLR) वर्ग के रूप में लागू किया गया है जिसमें केवल स्थिर सदस्य हैं।

इस स्थिति के आधार पर कि क्या पूरी फाइल को मॉड्यूल में शामिल किया गया है, दो प्रकार के मॉड्यूल घोषणाएं हैं -

  • शीर्ष स्तर के मॉड्यूल की घोषणा
  • स्थानीय मॉड्यूल की घोषणा

एक शीर्ष-स्तरीय मॉड्यूल घोषणा में पूरी फ़ाइल मॉड्यूल में शामिल होती है। इस स्थिति में, फ़ाइल में पहली घोषणा मॉड्यूल घोषणा है। आपको शीर्ष-स्तरीय मॉड्यूल में घोषणाओं को इंडेंट करने की आवश्यकता नहीं है।

एक स्थानीय मॉड्यूल घोषणा में, केवल उस मॉड्यूल घोषणा के तहत इंडेंट होने वाली घोषणाएं मॉड्यूल का हिस्सा होती हैं।

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

मॉड्यूल घोषणा के लिए सिंटैक्स निम्नानुसार है -

// Top-level module declaration.
module [accessibility-modifier] [qualified-namespace.]module-name
   declarations
// Local module declaration.
module [accessibility-modifier] module-name =
   declarations

कृपया ध्यान दें कि पहुँच-संशोधक निम्नलिखित में से एक हो सकता है - सार्वजनिक, निजी, आंतरिक। डिफ़ॉल्ट हैpublic

निम्नलिखित उदाहरण अवधारणाओं को प्रदर्शित करेंगे -

उदाहरण 1

मॉड्यूल फ़ाइल Arithmetic.fs -

module Arithmetic
let add x y =
   x + y

let sub x y =
   x - y
	
let mult x y =
   x * y
	
let div x y =
   x / y

कार्यक्रम फ़ाइल main.fs -

// Fully qualify the function name.
open Arithmetic
let addRes = Arithmetic.add 25 9
let subRes = Arithmetic.sub 25 9
let multRes = Arithmetic.mult 25 9
let divRes = Arithmetic.div 25 9

printfn "%d" addRes
printfn "%d" subRes
printfn "%d" multRes
printfn "%d" divRes

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

34
16
225
2
110
90
1000
10

उदाहरण 2

// Module1
module module1 =
   // Indent all program elements within modules that are declared with an equal sign.
   let value1 = 100
   let module1Function x =
      x + value1

// Module2
module module2 =
   let value2 = 200

   // Use a qualified name to access the function.
   // from module1.
   let module2Function x =
      x + (module1.module1Function value2)

let result = module1.module1Function 25
printfn "%d" result

let result2 = module2.module2Function 25
printfn "%d" result2

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

125
325

namespaceएक नाम को दूसरे से अलग रखने का एक तरीका प्रदान करने के लिए डिज़ाइन किया गया है। एक नाम स्थान में घोषित वर्ग नाम दूसरे में घोषित समान वर्ग नामों के साथ संघर्ष नहीं करेगा।

MSDN लाइब्रेरी के अनुसार, ए namespace प्रोग्राम तत्वों के समूह में नाम जोड़ने के लिए आपको संबंधित कार्यक्षमता के क्षेत्रों में कोड व्यवस्थित करने देता है।

एक नाम की घोषणा

अपने कोड को नेमस्पेस में व्यवस्थित करने के लिए, आपको फ़ाइल में पहले घोषणा के रूप में नेमस्पेस घोषित करना होगा। संपूर्ण फ़ाइल की सामग्री तब नामस्थान का हिस्सा बन जाती है।

namespace [parent-namespaces.]identifier

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

उदाहरण

namespace testing

module testmodule1 =
   let testFunction x y =
      printfn "Values from Module1: %A %A" x y
module testmodule2 =
   let testFunction x y =
      printfn "Values from Module2: %A %A" x y

module usermodule =
   do
      testmodule1.testFunction ( "one", "two", "three" ) 150
      testmodule2.testFunction (seq { for i in 1 .. 10 do yield i * i }) 200

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

Values from Module1: ("one", "two", "three") 150
Values from Module2: seq [1; 4; 9; 16; ...] 200