ThreadPoolExecutor 线程池
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | # coding: utf-8 from concurrent.futures import ThreadPoolExecutor, as_completed import time def spider(page): time.sleep(page) print (f "crawl task{page} finished" ) return page def main(): with ThreadPoolExecutor(max_workers = 5 ) as t: obj_list = [] for page in range ( 1 , 5 ): obj = t.submit(spider, page) obj_list.append(obj) for future in as_completed(obj_list): data = future.result() print (f "main: {data}" ) |
as_completed() 方法是一个生成器,在没有任务完成的时候,会一直阻塞,除非设置了 timeout。
当有某个任务完成的时候,会 yield 这个任务,就能执行 for 循环下面的语句,然后继续阻塞住,循环到所有的任务结束。同时,先完成的任务会先返回给主线程。
1 2 3 4 5 6 7 8 9 10 11 12 13 | from concurrent.futures import ThreadPoolExecutor, wait, FIRST_COMPLETED, ALL_COMPLETED import time def test(page): time.sleep(page) print (f "crawl task{page} finished" ) return page with ThreadPoolExecutor(max_workers = 5 ) as t: all_task = [t.submit(test, page) for page in range ( 1 , 5 )] wait(all_task, return_when = FIRST_COMPLETED) print ( 'finished' ) print (wait(all_task, timeout = 2.5 )) |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2021-11-30 Android 端测试app