python 等待线程结束,如何等待直到只有第一个线程在Python中完成

The requirement is to start five threads, and wait only in the fastest thread. All five threads went to look for the same data 5 directions, and one is enough to continue the control flow.

Actually, I need to wait for the first two threads to return, to verify against each other. But I guess if I know how to wait for the fastest. I can figure out how to wait for the second-fastest.

A lot talk about join(timeout), but you don't know in advance which one to wait (which one to apply join in advance).

解决方案

Use a queue: each thread when completed puts the result on the queue and then you just need to read the appropriate number of results and ignore the remainder:

#!python3.3

import queue # For Python 2.x use 'import Queue as queue'

import threading, time, random

def func(id, result_queue):

print("Thread", id)

time.sleep(random.random() * 5)

result_queue.put((id, 'done'))

def main():

q = queue.Queue()

threads = [ threading.Thread(target=func, args=(i, q)) for i in range(5) ]

for th in threads:

th.daemon = True

th.start()

result1 = q.get()

result2 = q.get()

print("Second result: {}".format(result2))

if __name__=='__main__':

main()

Documentation for Queue.get() (with no arguments it is equivalent to Queue.get(True, None):

Queue.get([block[, timeout]])

Remove and return an item from the

queue. If optional args block is true and timeout is None (the

default), block if necessary until an item is available. If timeout is

a positive number, it blocks at most timeout seconds and raises the

Empty exception if no item was available within that time. Otherwise

(block is false), return an item if one is immediately available, else

raise the Empty exception (timeout is ignored in that case).

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值