python中queue.Queue之task_done的理解

from threading import Thread
import time
from queue import Queue
q = Queue()
def run():
    while True:
        msg = q.get()
        print(msg)
        time.sleep(1)
        q.task_done()


for i in range(10):
    q.put(5-i)

for i in range(3):
    t = Thread(target=run)
    t.setDaemon(True)
    t.start()
q.join()

task_done目的是为了告诉队列, 我当前已经获取到队列中的内容, 当队列获取到所有线程中的此信号时, 会去会首先会不断检测是否有地方正在获取消息内容, 检测到后会继续检测队列中是否还有消息, 若有, 则会分发消息给get的地方, 如果没有, 则会终端join带来的阻塞, 继续往下执行。如果没有检测到有地方正在get到消息的话, 队列会不断的做这个检测, 从而阻塞在join那里, 也就是说, 如果在上述while True中加入了break语句, 导致所有线程不再get队列消息(实际线程已结束), 那么队列将会一直阻塞在join的地方

你可能感兴趣的:(python,后端,python,队列,queue)