हास्केल - कार्य
हास्केल में फ़ंक्शंस एक प्रमुख भूमिका निभाते हैं, क्योंकि यह एक कार्यात्मक प्रोग्रामिंग भाषा है। अन्य भाषाओं की तरह, हास्केल की अपनी कार्यात्मक परिभाषा और घोषणा है।
फ़ंक्शन घोषणा में फ़ंक्शन नाम और इसके आउटपुट के साथ इसकी तर्क सूची शामिल होती है।
फ़ंक्शन परिभाषा वह जगह है जहां आप वास्तव में एक फ़ंक्शन को परिभाषित करते हैं।
आइए हम छोटे उदाहरण लेते हैं add इस अवधारणा को विस्तार से समझने के लिए कार्य करें।
add :: Integer -> Integer -> Integer --function declaration
add x y = x + y --function definition
main = do
putStrLn "The addition of the two numbers is:"
print(add 2 5) --calling a function
यहां, हमने अपने कार्य को पहली पंक्ति में और दूसरी पंक्ति में घोषित किया है, हमने अपना वास्तविक कार्य लिखा है जो दो तर्क देगा और एक पूर्णांक प्रकार का उत्पादन करेगा।
अधिकांश अन्य भाषाओं की तरह, हास्केल से कोड का संकलन शुरू होता है mainतरीका। हमारा कोड निम्नलिखित आउटपुट उत्पन्न करेगा -
The addition of the two numbers is:
7
पैटर्न मिलान
पैटर्न मिलान विशिष्ट प्रकार के अभिव्यक्तियों के मिलान की प्रक्रिया है। यह आपके कोड को सरल बनाने की तकनीक के अलावा और कुछ नहीं है। इस तकनीक को किसी भी प्रकार की टाइप क्लास में लागू किया जा सकता है। अगर-एल्स का उपयोग पैटर्न मिलान के वैकल्पिक विकल्प के रूप में किया जा सकता है।
पैटर्न मिलान को गतिशील बहुरूपता का एक प्रकार माना जा सकता है जहां रनटाइम के दौरान, विभिन्न तरीकों को अपने तर्क सूची के आधार पर निष्पादित किया जा सकता है।
निम्नलिखित कोड ब्लॉक पर एक नज़र डालें। यहां हमने किसी संख्या के भाज्य की गणना के लिए पैटर्न मिलान की तकनीक का उपयोग किया है।
fact :: Int -> Int
fact 0 = 1
fact n = n * fact ( n - 1 )
main = do
putStrLn "The factorial of 5 is:"
print (fact 5)
हम सभी जानते हैं कि किसी संख्या के भाज्य की गणना कैसे की जाती है। संकलक एक तर्क के साथ "तथ्य" नामक फ़ंक्शन की खोज शुरू करेगा। यदि तर्क 0 के बराबर नहीं है, तो संख्या वास्तविक तर्क की तुलना में 1 के साथ एक ही फ़ंक्शन को कॉल करती रहेगी।
जब तर्क का पैटर्न ठीक 0 से मेल खाता है, तो यह हमारे पैटर्न को "तथ्य 0 = 1" कहेगा। हमारा कोड निम्न आउटपुट का उत्पादन करेगा -
The factorial of 5 is:
120
गार्ड
Guardsएक अवधारणा है जो पैटर्न मिलान के समान है। पैटर्न मिलान में, हम आमतौर पर एक या अधिक अभिव्यक्तियों से मेल खाते हैं, लेकिन हम उपयोग करते हैंguards एक अभिव्यक्ति की कुछ संपत्ति का परीक्षण करने के लिए।
हालाँकि यह सलाह दी जाती है कि पैटर्न से मेल खाते हुए का उपयोग करें guards, लेकिन एक डेवलपर के दृष्टिकोण से, guardsअधिक पठनीय और सरल है। पहली बार उपयोगकर्ताओं के लिए,guards इफ-एल्स बयानों के समान दिख सकते हैं, लेकिन वे कार्यात्मक रूप से भिन्न हैं।
निम्नलिखित कोड में, हमने अपने को संशोधित किया है factorial की अवधारणा का उपयोग करके कार्यक्रम guards।
fact :: Integer -> Integer
fact n | n == 0 = 1
| n /= 0 = n * fact (n-1)
main = do
putStrLn "The factorial of 5 is:"
print (fact 5)
यहां, हमने दो घोषित किए हैं guards, "|" और बुला रहा हैfact से कार्य करते हैं main। आंतरिक रूप से, कंपाइलर उसी तरीके से काम करेगा जैसे पैटर्न के मामले में निम्नलिखित आउटपुट प्राप्त करने के लिए -
The factorial of 5 is:
120
कहां कारण
Whereएक कीवर्ड या इनबिल्ट फंक्शन है जिसका उपयोग रनटाइम में एक वांछित आउटपुट उत्पन्न करने के लिए किया जा सकता है। जब फ़ंक्शन गणना जटिल हो जाती है तो यह बहुत उपयोगी हो सकता है।
एक परिदृश्य पर विचार करें जहां आपका इनपुट कई मापदंडों के साथ एक जटिल अभिव्यक्ति है। ऐसे मामलों में, आप "जहां" खंड का उपयोग करके पूरी अभिव्यक्ति को छोटे भागों में तोड़ सकते हैं।
निम्नलिखित उदाहरण में, हम एक जटिल गणितीय अभिव्यक्ति ले रहे हैं। हम दिखाएंगे कि आप हास्केल का उपयोग करके एक बहुपद समीकरण [x ^ 2 - 8x + 6] की जड़ें कैसे पा सकते हैं।
roots :: (Float, Float, Float) -> (Float, Float)
roots (a,b,c) = (x1, x2) where
x1 = e + sqrt d / (2 * a)
x2 = e - sqrt d / (2 * a)
d = b * b - 4 * a * c
e = - b / (2 * a)
main = do
putStrLn "The roots of our Polynomial equation are:"
print (roots(1,-8,6))
दिए गए बहुपद समारोह की जड़ों की गणना करने के लिए हमारी अभिव्यक्ति की जटिलता पर ध्यान दें। यह काफी जटिल है। इसलिए, हम अभिव्यक्ति का उपयोग करके अभिव्यक्ति को तोड़ रहे हैंwhereखंड। उपरोक्त कोड का कोड निम्न आउटपुट उत्पन्न करेगा -
The roots of our Polynomial equation are:
(7.1622777,0.8377223)
पुनरावृत्ति समारोह
पुनरावृत्ति एक ऐसी स्थिति है जहां एक फ़ंक्शन बार-बार खुद को कॉल करता है। हास्केल एक से अधिक बार किसी भी अभिव्यक्ति को लूप करने की कोई सुविधा प्रदान नहीं करता है। इसके बजाय, हास्केल चाहता है कि आप अपनी पूरी कार्यक्षमता को विभिन्न कार्यों के संग्रह में तोड़ दें और अपनी कार्यक्षमता को लागू करने के लिए पुनरावर्तन तकनीक का उपयोग करें।
आइए हम अपने पैटर्न मिलान उदाहरण पर फिर से विचार करें, जहां हमने किसी संख्या के गुणन की गणना की है। एक संख्या के भाज्य का पता लगाना रिकर्सन का उपयोग करने का एक क्लासिक मामला है। यहाँ, आप "पुनरावृत्ति से किसी भी भिन्न मिलान कैसे कर सकते हैं?" इन दोनों के बीच का अंतर उनके उपयोग करने के तरीके में है। पैटर्न की मैचिंग टर्मिनल की कमी को स्थापित करने पर काम करती है, जबकि पुनरावृत्ति एक फ़ंक्शन कॉल है।
निम्नलिखित उदाहरण में, हमने 5 के भाज्य की गणना करने के लिए पैटर्न मिलान और पुनरावृत्ति दोनों का उपयोग किया है।
fact :: Int -> Int
fact 0 = 1
fact n = n * fact ( n - 1 )
main = do
putStrLn "The factorial of 5 is:"
print (fact 5)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
The factorial of 5 is:
120
उच्च आदेश समारोह
अब तक, हमने जो देखा है, वह यह है कि हास्केल फंक्शन में से एक लेता है type इनपुट के रूप में और एक और उत्पादन typeआउटपुट के रूप में, जो अन्य अनिवार्य भाषाओं में बहुत समान है। हायर ऑर्डर फ़ंक्शंस हास्केल की एक अनूठी विशेषता है जहां आप एक फ़ंक्शन को इनपुट या आउटपुट तर्क के रूप में उपयोग कर सकते हैं।
यद्यपि यह एक आभासी अवधारणा है, लेकिन वास्तविक दुनिया के कार्यक्रमों में, हर फ़ंक्शन जिसे हम हास्केल में परिभाषित करते हैं, आउटपुट प्रदान करने के लिए उच्च-क्रम तंत्र का उपयोग करते हैं। यदि आपको हास्केल के पुस्तकालय समारोह को देखने का मौका मिलता है, तो आप पाएंगे कि अधिकांश पुस्तकालय कार्यों को उच्चतर क्रम में लिखा गया है।
आइए एक उदाहरण लेते हैं जहां हम एक इनबिल्ट हायर ऑर्डर फंक्शन मैप को इम्पोर्ट करेंगे और अपनी पसंद के अनुसार दूसरे हाई ऑर्डर फंक्शन को लागू करने के लिए उसी का इस्तेमाल करेंगे।
import Data.Char
import Prelude hiding (map)
map :: (a -> b) -> [a] -> [b]
map _ [] = []
map func (x : abc) = func x : map func abc
main = print $ map toUpper "tutorialspoint.com"
उपरोक्त उदाहरण में, हमने उपयोग किया है toUpper प्रकार वर्ग का कार्य Charहमारे इनपुट को अपरकेस में बदलने के लिए। यहां, विधि "मानचित्र" एक फ़ंक्शन को एक तर्क के रूप में ले रहा है और आवश्यक आउटपुट वापस कर रहा है। यहाँ इसका उत्पादन है -
sh-4.3$ ghc -O2 --make *.hs -o main -threaded -rtsopts
sh-4.3$ main
"TUTORIALSPOINT.COM"
लैम्ब्डा एक्सप्रेशन
हमें कभी-कभी एक फ़ंक्शन लिखना पड़ता है जो एक आवेदन के पूरे जीवनकाल में केवल एक बार उपयोग होने वाला है। इस तरह की स्थितियों से निपटने के लिए, हास्केल डेवलपर्स एक अन्य अनाम ब्लॉक का उपयोग करते हैं, जिसे जाना जाता हैlambda expression या lambda function।
एक परिभाषा के बिना एक फ़ंक्शन को लंबो फ़ंक्शन कहा जाता है। एक लैम्ब्डा फ़ंक्शन को "\" वर्ण द्वारा निरूपित किया जाता है। आइए हम निम्नलिखित उदाहरण लेते हैं जहां हम किसी फ़ंक्शन को बनाए बिना इनपुट मान को 1 से बढ़ाएंगे।
main = do
putStrLn "The successor of 4 is:"
print ((\x -> x + 1) 4)
यहां, हमने एक अनाम फ़ंक्शन बनाया है जिसमें कोई नाम नहीं है। यह पूर्णांक 4 को एक तर्क के रूप में लेता है और आउटपुट मूल्य को प्रिंट करता है। हम मूल रूप से एक फ़ंक्शन को ठीक से घोषित किए बिना भी काम कर रहे हैं। यही लंबोदर भावों का सौंदर्य है।
हमारी लैम्ब्डा अभिव्यक्ति निम्नलिखित उत्पादन का उत्पादन करेगी -
sh-4.3$ main
The successor of 4 is:
5