पायथन डिज़ाइन पैटर्न - कतार

कतार वस्तुओं का एक संग्रह है, जो 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

उत्पादन

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