Python-Entwurfsmuster - Warteschlangen
Die Warteschlange ist eine Sammlung von Objekten, die eine einfache Datenstruktur nach den Prozeduren FIFO (Fast In Fast Out) und LIFO (Last In First Out) definieren. Die Einfüge- und Löschvorgänge werden als bezeichnetenqueue und dequeue Operationen.
Warteschlangen erlauben keinen wahlfreien Zugriff auf die darin enthaltenen Objekte.
Wie implementiere ich das FIFO-Verfahren?
Das folgende Programm hilft bei der Implementierung von 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()
Ausgabe
Das obige Programm erzeugt die folgende Ausgabe -
Wie implementiere ich das LIFO-Verfahren?
Das folgende Programm hilft bei der Implementierung des LIFO-Verfahrens -
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()
Ausgabe
Das obige Programm erzeugt die folgende Ausgabe -
Was ist eine Prioritätswarteschlange?
Die Prioritätswarteschlange ist eine Containerdatenstruktur, die eine Reihe von Datensätzen mit den geordneten Schlüsseln verwaltet, um einen schnellen Zugriff auf den Datensatz mit dem kleinsten oder größten Schlüssel in der angegebenen Datenstruktur zu ermöglichen.
Wie implementiere ich eine Prioritätswarteschlange?
Die Implementierung der Prioritätswarteschlange ist wie folgt:
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
Ausgabe
Das obige Programm erzeugt die folgende Ausgabe -