पायथन डिज़ाइन पैटर्न - कतार
कतार वस्तुओं का एक संग्रह है, जो FIFO (फास्ट इन फास्ट आउट) और LIFO (लास्ट इन फर्स्ट आउट) प्रक्रियाओं के बाद एक सरल डेटा संरचना को परिभाषित करता है। डालने और हटाने के संचालन के रूप में संदर्भित किया जाता हैenqueue तथा dequeue संचालन।
कतारें उन वस्तुओं तक यादृच्छिक पहुँच की अनुमति नहीं देती हैं जिनमें वे शामिल हैं।
FIFO प्रक्रिया कैसे लागू करें?
निम्नलिखित कार्यक्रम FIFO के कार्यान्वयन में मदद करता है -
import Queue
q = Queue.Queue()
#put items at the end of the queue
for x in range(4):
q.put("item-" + str(x))
#remove items from the head of the queue
while not q.empty():
print q.get()
उत्पादन
उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -
LIFO प्रक्रिया कैसे लागू करें?
निम्नलिखित कार्यक्रम LIFO प्रक्रिया के कार्यान्वयन में मदद करता है -
import Queue
q = Queue.LifoQueue()
#add items at the head of the queue
for x in range(4):
q.put("item-" + str(x))
#remove items from the head of the queue
while not q.empty():
print q.get()
उत्पादन
उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -
प्राथमिकता कतार क्या है?
प्राथमिकता कतार एक कंटेनर डेटा संरचना है जो निर्दिष्ट डेटा संरचना में सबसे छोटी या सबसे बड़ी कुंजी के साथ रिकॉर्ड तक त्वरित पहुंच प्रदान करने के लिए आदेशित कुंजियों के साथ रिकॉर्ड का एक सेट प्रबंधित करती है।
प्राथमिकता कतार कैसे लागू करें?
प्राथमिकता कतार का कार्यान्वयन निम्नानुसार है -
import Queue
class Task(object):
def __init__(self, priority, name):
self.priority = priority
self.name = name
def __cmp__(self, other):
return cmp(self.priority, other.priority)
q = Queue.PriorityQueue()
q.put( Task(100, 'a not agent task') )
q.put( Task(5, 'a highly agent task') )
q.put( Task(10, 'an important task') )
while not q.empty():
cur_task = q.get()
print 'process task:', cur_task.name
उत्पादन
उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -