温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Python多线程中Queue模块怎么用

发布时间:2021-07-05 09:46:18 来源:亿速云 阅读:165 作者:小新 栏目:开发技术

这篇文章将为大家详细讲解有关Python多线程中Queue模块怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

queue介绍

queue是python中的标准库,俗称队列,可以直接import 引用,在python2.x中,模块名为Queue
在python中,多个线程之间的数据是共享的,多个线程进行数据交换的时候,不能够保证数据的安全性和一致性,所以当多个线程需要进行数据交换的时候,队列就出现了,队列可以完美解决线程间的数据交换,保证线程间数据的安全性和一致性

Python 的 Queue 模块中提供了同步的、线程安全的队列类,包括FIFO(先入先出)队列Queue,LIFO(后入先出)队列LifoQueue,和优先级队列 PriorityQueue。

这些队列都实现了锁原语,能够在多线程中直接使用,可以使用队列来实现线程间的同步。
Queue 模块中的常用方法:

Queue.qsize() 返回队列的大小
Queue.empty() 如果队列为空,返回True,反之False
Queue.full() 如果队列满了,返回True,反之False
Queue.full 与 maxsize 大小对应
Queue.get([block[, timeout]])获取队列,timeout等待时间
Queue.get_nowait() 相当Queue.get(False)
Queue.put(item) 写入队列,timeout等待时间
Queue.put_nowait(item) 相当Queue.put(item, False)
Queue.task_done() 在完成一项工作之后,Queue.task_done()函数向任务已经完成的队列发送一个信号
Queue.join() 实际上意味着等到队列为空,再执行别的操作

import threading import time def a():     print("a start\n")     for i in range(10):         time.sleep(0.1)     print("a finish\n") def b():     print("b start\n")     print("b finish\n") def main():     # t=threading.Thread(target=a,name="T")     t = threading.Thread(target=a)     t2=threading.Thread(target=b)     t.start()     t2.start()     # t2.join()     # t.join()     print("all done\n") if __name__ == '__main__':     main()

Queue 模块:

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 ("开启线程:" + self.name)         process_data(self.name, self.q)         print ("退出线程:" + 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 # 创建新线程 for tName in threadList:     thread = myThread(threadID, tName, workQueue)     thread.start()     threads.append(thread)     threadID += 1 # 填充队列 queueLock.acquire() for word in nameList:     workQueue.put(word) queueLock.release() # 等待队列清空 while not workQueue.empty():     pass # 通知线程是时候退出 exitFlag = 1 # 等待所有线程完成 for t in threads:     t.join() print ("退出主线程")

关于“Python多线程中Queue模块怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI