एर्लांग - कार्य

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

एक कार्य को परिभाषित करना

फ़ंक्शन घोषणा का सिंटैक्स निम्नानुसार है -

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

FunctionName(Pattern1… PatternN) ->
Body;

कहाँ पे,

  • FunctionName - फ़ंक्शन नाम एक परमाणु है।

  • Pattern1… PatternN- प्रत्येक तर्क एक पैटर्न है। तर्कों की संख्या N फ़ंक्शन की विविधता है। एक फ़ंक्शन विशिष्ट रूप से मॉड्यूल नाम, फ़ंक्शन नाम और एरिटी द्वारा परिभाषित किया गया है। यही है, एक ही नाम के साथ और एक ही मॉड्यूल में दो फ़ंक्शन, लेकिन अलग-अलग आर्कियों के साथ दो अलग-अलग फ़ंक्शन हैं।

  • Body - एक खंड शरीर में अल्पविराम (,) द्वारा अलग किए गए भावों का एक क्रम होता है:

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

उदाहरण

-module(helloworld). 
-export([add/2,start/0]). 

add(X,Y) -> 
   Z = X+Y, 
   io:fwrite("~w~n",[Z]). 
   
start() -> 
   add(5,6).

उपरोक्त कार्यक्रम के बारे में निम्नलिखित बिंदुओं पर ध्यान दिया जाना चाहिए -

  • हम दो कार्यों को परिभाषित कर रहे हैं, एक कहा जाता है add जो 2 पैरामीटर लेता है और दूसरा है start समारोह।

  • दोनों फ़ंक्शन निर्यात फ़ंक्शन के साथ परिभाषित किए गए हैं। यदि हम ऐसा नहीं करते हैं, तो हम फ़ंक्शन का उपयोग नहीं कर पाएंगे।

  • एक फ़ंक्शन को दूसरे के अंदर बुलाया जा सकता है। यहां हम ऐड फंक्शन को स्टार्ट फंक्शन से बुला रहे हैं।

उपरोक्त कार्यक्रम का उत्पादन होगा -

उत्पादन

11

अनाम कार्य

एक अनाम फ़ंक्शन एक फ़ंक्शन है, जिसका इसके साथ कोई नाम जुड़ा नहीं है। एरलंग में अनाम कार्यों को परिभाषित करने की सुविधा है। निम्नलिखित कार्यक्रम एक अनाम फ़ंक्शन का एक उदाहरण है।

उदाहरण

-module(helloworld). 
-export([start/0]). 

start() -> 
   Fn = fun() -> 
      io:fwrite("Anonymous Function") end, 
   Fn().

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

  • अनाम फ़ंक्शन के साथ परिभाषित किया गया है fun() कीवर्ड।

  • फ़ंक्शन को फ़र्न नामक एक चर को सौंपा गया है।

  • फ़ंक्शन को चर नाम के माध्यम से कहा जाता है।

उपरोक्त कार्यक्रम का उत्पादन होगा -

उत्पादन

Anonymous Function

एकाधिक तर्क के साथ कार्य

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

निम्न उदाहरण में, फ़ंक्शन डेमो को प्रत्येक फ़ंक्शन परिभाषा के लिए कई तर्कों के साथ परिभाषित किया गया है।

उदाहरण

-module(helloworld). 
-export([add/2,add/3,start/0]). 

add(X,Y) -> 
   Z = X+Y, 
   io:fwrite("~w~n",[Z]). 
   
add(X,Y,Z) -> 
   A = X+Y+Z, 
   io:fwrite("~w~n",[A]). 
 
start() ->
   add(5,6), 
   add(5,6,6).

उपरोक्त कार्यक्रम में, हम दो बार फ़ंक्शन को परिभाषित कर रहे हैं। लेकिन पहले ऐड फंक्शन की परिभाषा दो मापदंडों में होती है और दूसरा तीन मापदंडों में होती है।

उपरोक्त कार्यक्रम का उत्पादन होगा -

उत्पादन

11
17

गार्ड अनुक्रम के साथ कार्य

Erlang में क्रियाओं में गार्ड अनुक्रम होने की क्षमता भी होती है। ये कुछ भी नहीं बल्कि भाव हैं जो केवल सत्य का मूल्यांकन करने पर फ़ंक्शन को चलाने का कारण बनेंगे।

एक गार्ड अनुक्रम के साथ एक फ़ंक्शन का सिंटैक्स निम्न प्रोग्राम में दिखाया गया है।

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

FunctionName(Pattern1… PatternN) [when GuardSeq1]->
Body;

कहाँ पे,

  • FunctionName - फ़ंक्शन नाम एक परमाणु है।

  • Pattern1… PatternN- प्रत्येक तर्क एक पैटर्न है। तर्कों की संख्या N फ़ंक्शन की विविधता है। एक फ़ंक्शन विशिष्ट रूप से मॉड्यूल नाम, फ़ंक्शन नाम और एरिटी द्वारा परिभाषित किया गया है। यही है, एक ही नाम के साथ और एक ही मॉड्यूल में दो फ़ंक्शन, लेकिन अलग-अलग आर्कियों के साथ दो अलग-अलग फ़ंक्शन हैं।

  • Body - एक खंड शरीर में अभिव्यक्ति के अनुक्रम होते हैं, जो अल्पविराम (,) द्वारा अलग किए जाते हैं।

  • GuardSeq1 - यह वह एक्सप्रेशन है जिसका फंक्शन होने पर मूल्यांकन किया जाता है।

निम्नलिखित कार्यक्रम एक गार्ड अनुक्रम के साथ एक फ़ंक्शन के उपयोग का एक सरल उदाहरण है।

उदाहरण

-module(helloworld). 
-export([add/1,start/0]). 

add(X) when X>3 -> 
   io:fwrite("~w~n",[X]). 

start() -> 
   add(4).

उपरोक्त कार्यक्रम का आउटपुट है -

उत्पादन

4

यदि ऐड फंक्शन को कहा जाता है add(3)कार्यक्रम में एक त्रुटि होगी।