如何使用多线程高效执行包含大量字典参数的列表函数?

如何使用多线程高效执行包含大量字典参数的列表函数?

列表内的字典参数多线程执行

拥有包含大量字典参数的列表,需要依次使用多线程执行指定的函数,并自定义线程数。

实现方法:

可以使用threadpoolexecutor线程池来实现此功能。该类可创建指定数量的线程,并根据需要分配和释放线程

以下是实现代码:

import time
from concurrent.futures import ThreadPoolExecutor
import threading

my_list = [
    {'ip': '192.168.1.2', 'password': '123456', 'user_name': '654321'},
    {'ip': '192.168.1.3', 'password': '123456', 'user_name': '654321'},
    {'ip': '192.168.1.4', 'password': '123456', 'user_name': '654321'},
    {'ip': '192.168.1.5', 'password': '123456', 'user_name': '654321'},
    {'ip': '192.168.1.6', 'password': '123456', 'user_name': '654321'}
]


def dosome(ip, password, user_name):
    tname = threading.current_thread().getName()
    time.sleep(1)
    print(f'{tname} {ip}')


tpe = ThreadPoolExecutor(max_workers=3)

for m in my_list:
    tpe.submit(dosome, **m)

此代码创建一个具有 3 个工作线程线程池(max_workers=3),并依次将字典参数传递给 dosome 函数。

线程池会自动管理线程的创建和销毁。在所有任务完成之前,线程池仍会处于活动状态。一旦所有任务完成,线程池将关闭,释放所有资源。

以上就是如何使用多线程高效执行包含大量字典参数的列表函数?的详细内容,更多请关注硕下网其它相关文章!