लुआ - इटरेटर

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

जेनरेटर फॉर इटरेटर

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

array = {"Lua", "Tutorial"}

for key,value in ipairs(array) 
do
   print(key, value)
end

जब हम उपरोक्त कोड चलाते हैं, तो हमें निम्न आउटपुट मिलेगा -

1  Lua
2  Tutorial

उपरोक्त उदाहरण Lua द्वारा प्रदान की गई डिफ़ॉल्ट ipairs पुनरावृत्ति फ़ंक्शन का उपयोग करता है ।

लुआ में हम पुनरावृत्तियों का प्रतिनिधित्व करने के लिए कार्यों का उपयोग करते हैं। इन पुनरावृत्त कार्यों में राज्य के रखरखाव के आधार पर, हमारे पास दो मुख्य प्रकार हैं -

  • स्टेटलेस इटरेटर
  • स्टेटफुल इटरेटर

स्टेटलेस इटरेटर

नाम से ही हम समझ सकते हैं कि इस प्रकार के पुनरावृत्त समारोह किसी भी राज्य को बनाए नहीं रखते हैं।

आइए अब हम एक साधारण फ़ंक्शन का उपयोग करके अपने स्वयं के इटेरेटर बनाने का एक उदाहरण देखते हैं जो के वर्गों को प्रिंट करता है n संख्या।

function square(iteratorMaxCount,currentNumber)

   if currentNumber<iteratorMaxCount
   then
      currentNumber = currentNumber+1
      return currentNumber, currentNumber*currentNumber
   end
	
end

for i,n in square,3,0
do
   print(i,n)
end

जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेगा।

1	1
2	4
3	9

उपर्युक्त कोड को पुनरावृत्त करने के लिए थोड़ा संशोधित किया जा सकता है जिस तरह से पुनरावृत्तियां कार्य करती हैं। इसे नीचे दिखाया गया है।

function square(iteratorMaxCount,currentNumber)

   if currentNumber<iteratorMaxCount
   then
      currentNumber = currentNumber+1
      return currentNumber, currentNumber*currentNumber
   end
	
end

function squares(iteratorMaxCount)
   return square,iteratorMaxCount,0
end  

for i,n in squares(3)
do 
   print(i,n)
end

जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेगा।

1	1
2	4
3	9

स्टेटफुल इटरेटर

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

आइए अब अपने स्वयं के पुनरावृत्तियों को बनाने का एक उदाहरण देखते हैं जिसमें हम क्लोजर का उपयोग करेंगे।

array = {"Lua", "Tutorial"}

function elementIterator (collection)

   local index = 0
   local count = #collection
	
   -- The closure function is returned
	
   return function ()
      index = index + 1
		
      if index <= count
      then
         -- return the current element of the iterator
         return collection[index]
      end
		
   end
	
end

for element in elementIterator(array)
do
   print(element)
end

जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेगा।

Lua
Tutorial

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

हम ऊपर दिखाए गए अनुसार क्लोजर का उपयोग करके अपने स्वयं के फ़ंक्शन पुनरावृत्तियों को बना सकते हैं और संग्रह के माध्यम से पुनरावृति करने वाले प्रत्येक समय के लिए कई तत्वों को वापस कर सकते हैं।