Rexx - ढेर

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

एक स्टैक के उदाहरण पर एक नज़र डालते हैं।

/* STACK: */
/* */ 
/* This program shows how to use the Rexx Stack as either a */ 

/* stack or a queue. */ 
do j = 1 to 3 
push ‘Stack: line #’ || j 

/* push 3 lines onto the stack */ 
end 
do j = 1 to queued() 

/* retrieve and display LIFO */ 
pull line 
say line 
end 
do j = 1 to 3 queue ‘Queue: line #’ || j 

/* queue 3 lines onto the stack */ 
end 
do queued() 

/* retrieve and display FIFO */ 
pull line 
say line 
end 
exit 0

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

पुश निर्देश द्वारा स्टैक में रखी गई वस्तुओं को LIFO क्रम में पुनः प्राप्त किया जाता है -

do j = 1 to 3 
push ‘Stack: line #’ || j     /* push 3 lines onto the stack */ 
end

अगला कोड ब्लॉक स्टैक पर लाइनों की संख्या की खोज करने के लिए कतारबद्ध अंतर्निहित फ़ंक्शन का उपयोग दिखाता है, साथ ही स्टैक से सभी लाइनों को पुनः प्राप्त करने के लिए एक लूप -

do j = 1 to queued()    /* retrieve and display LIFO */ 
pull line 
say line 
end

चूँकि तीन वस्तुओं को स्टैक पर पुश के माध्यम से रखा गया था, इसलिए उन्हें LIFO क्रम में पुनः प्राप्त किया जाता है।

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा।

STACK: LINE #3 
STACK: LINE #2 
STACK: LINE #1