queue.put(item, block=True, timeout=None)
"""将item消息写入队列,block默认值为True;
如果block使用默认值,且没有设置timeout(单位秒),消息列队如果已
经没有空间可写入,此时程序将被阻塞(停在写入状态),直到从消息列队腾
出空间为止,如果设置了timeout,则会等待timeout秒,若还没空间,则
抛出"Queue.Full"异常;
如果block值为False,消息列队如果没有空间可写入,则会立刻抛
出"Queue.Full"异常;
"""
queue.get(item, block=True, timeout=None)
"""
获取队列中的一条消息,然后将其从队列中移除,block默认值为True。如
果block使用默认值,且没有设置timeout(单位秒),消息列队如果为
空,此时程序将被阻塞(停在读取状态),直到从消息列队读到消息为止,如
果设置了timeout,则会等待timeout秒,若还没读取到任何消息,则抛
出"Queue.Empty"异常;
如果block值为False,消息列队如果为空,则会立刻抛
出"Queue.Empty"异常;
"""
# get方法并不能让queue的计数-1,必须调用task_done
queue.task_done()
queue.join() # 主程序阻塞,等待队列计数为0时才继续向下执行
线程池优点:
1. 降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造
成的消耗。
2. 提高响应速度。当任务到达时,任务可以不需要等到线程创建就能
立即执行。
3. 提高线程的可管理性。线程是稀缺资源,如果无限制的创建,不仅
会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统
一的分配,调优和监控
Python中的进程与线程的使用场景:
多进程适合在 CPU 密集型操作(cpu 操作指令比较多,如位数多的浮
点运算)。
多线程适合在 IO 密集型操作(读写数据操作较多的,比如爬虫、网
络编程)。