ThreadPoolExecutor传递单个参数和多个参数

文章展示了如何在Python中使用ThreadPoolExecutor进行线程池操作,包括限制最大线程数以及如何传递单个参数和多个参数。在处理单个参数时,直接提交任务;而在传递多个参数时,使用lambda函数拆解参数并保证任务执行。需要注意的是,多线程环境下输出顺序可能不可预测。
Python3.8

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

ThreadPoolExecutor传递单个参数:

from concurrent.futures import ThreadPoolExecutor

# 采取线程池机制,限制线程的最大数量
maxThreadLimit = 1000
threadPool = ThreadPoolExecutor(max_workers=maxThreadLimit)


def test(a):
    print(a)


ls = [1, 2, 3, 4, 5, 6]
# ThreadPoolExecutor单个参数传值
[threadPool.submit(test, i) for i in ls]

ThreadPoolExecutor传递多个参数:

from concurrent.futures import ThreadPoolExecutor

# 采取线程池机制,限制线程的最大数量
maxThreadLimit = 1000
threadPool = ThreadPoolExecutor(max_workers=maxThreadLimit)


def test(k, v):
    print(k, v)


dic = {'1': 1, '2': 2, '3': 3, '4': 4, '5': 5}
# ThreadPoolExecutor多个参数传值,但多线程可能会导致输出顺序乱掉
[threadPool.submit(lambda args: test(*args), (k, v)) for k, v in dic.items()]

您可能感兴趣的与本文相关的镜像

Python3.8

Python3.8

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值