সারি মডিউল আপনাকে একটি নতুন সারি অবজেক্ট তৈরি করতে দেয় যা একটি নির্দিষ্ট সংখ্যক আইটেম ধারণ করতে পারে। সারি নিয়ন্ত্রণ করার জন্য নিম্নলিখিত পদ্ধতি রয়েছে -
- পান() − get() সারি থেকে একটি আইটেম সরিয়ে দেয় এবং ফেরত দেয়।
- পুট() − পুট একটি সারিতে আইটেম যোগ করে।
- qsize() − qsize() বর্তমানে সারিতে থাকা আইটেমের সংখ্যা প্রদান করে।
- খালি() − সারি খালি থাকলে খালি() True দেখায়; অন্যথায়, মিথ্যা।
- পূর্ণ() − সারি পূর্ণ হলে পূর্ণ() সত্য প্রদান করে; অন্যথায়, মিথ্যা।
উদাহরণ
#!/usr/bin/python import Queue import threading import time exitFlag = 0 class myThread (threading.Thread): def __init__(self, threadID, name, q): threading.Thread.__init__(self) self.threadID = threadID self.name = name self.q = q def run(self): print "Starting " + self.name process_data(self.name, self.q) print "Exiting " + self.name def process_data(threadName, q): while not exitFlag: queueLock.acquire() if not workQueue.empty(): data = q.get() queueLock.release() print "%s processing %s" % (threadName, data) else: queueLock.release() time.sleep(1) threadList = ["Thread-1", "Thread-2", "Thread-3"] nameList = ["One", "Two", "Three", "Four", "Five"] queueLock = threading.Lock() workQueue = Queue.Queue(10) threads = [] threadID = 1 # Create new threads for tName in threadList: thread = myThread(threadID, tName, workQueue) thread.start() threads.append(thread) threadID += 1 # Fill the queue queueLock.acquire() for word in nameList: workQueue.put(word) queueLock.release() # Wait for queue to empty while not workQueue.empty(): pass # Notify threads it's time to exit exitFlag = 1 # Wait for all threads to complete for t in threads: t.join() print "Exiting Main Thread"
উপরের কোডটি কার্যকর করা হলে, এটি নিম্নলিখিত ফলাফল তৈরি করে -
Starting Thread-1 Starting Thread-2 Starting Thread-3 Thread-1 processing One Thread-2 processing Two Thread-3 processing Three Thread-1 processing Four Thread-2 processing Five Exiting Thread-3 Exiting Thread-1 Exiting Thread-2 Exiting Main Thread