Modèles de conception Python - Files d'attente
Queue est un ensemble d'objets qui définissent une structure de données simple suivant les procédures FIFO (Fast In Fast Out) et LIFO (Last In First Out). Les opérations d'insertion et de suppression sont appeléesenqueue et dequeue opérations.
Les files d'attente n'autorisent pas l'accès aléatoire aux objets qu'elles contiennent.
Comment mettre en œuvre la procédure FIFO?
Le programme suivant aide à la mise en œuvre du 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()
Production
Le programme ci-dessus génère la sortie suivante -
Comment mettre en œuvre la procédure LIFO?
Le programme suivant aide à la mise en œuvre de la procédure 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()
Production
Le programme ci-dessus génère la sortie suivante -
Qu'est-ce qu'une file d'attente prioritaire?
La file d'attente prioritaire est une structure de données de conteneur qui gère un ensemble d'enregistrements avec les clés ordonnées pour fournir un accès rapide à l'enregistrement avec la clé la plus petite ou la plus grande dans la structure de données spécifiée.
Comment mettre en place une file d'attente prioritaire?
La mise en œuvre de la file d'attente prioritaire est la suivante -
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
Production
Le programme ci-dessus génère la sortie suivante -