Pola Desain Python - Antrian

Antrian adalah kumpulan objek, yang mendefinisikan struktur data sederhana mengikuti prosedur FIFO (Fast In Fast Out) dan LIFO (Last In First Out). Operasi penyisipan dan penghapusan disebut sebagaienqueue dan dequeue operasi.

Antrian tidak mengizinkan akses acak ke objek yang dikandungnya.

Bagaimana cara menerapkan prosedur FIFO?

Program berikut membantu dalam penerapan 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()

Keluaran

Program di atas menghasilkan keluaran berikut -

Bagaimana cara menerapkan prosedur LIFO?

Program berikut membantu dalam implementasi prosedur 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()

Keluaran

Program di atas menghasilkan keluaran berikut -

Apa itu Antrian Prioritas?

Antrian prioritas adalah struktur data kontainer yang mengelola sekumpulan record dengan kunci yang diurutkan untuk menyediakan akses cepat ke record dengan kunci terkecil atau terbesar dalam struktur data yang ditentukan.

Bagaimana cara menerapkan antrian prioritas?

Implementasi antrian prioritas adalah sebagai berikut -

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

Keluaran

Program di atas menghasilkan keluaran berikut -