python 简易多线程执行函数

引入并实例化线程池

from concurrent.futures import ThreadPoolExecutor

N = 4 # 线程数量
pool = ThreadPoolExecutor(max_workers=N) # 建立线程池

使用方式:其中 func 为函数,data 为需要处理的数据 (列表)

pool.map(func, data)

例如:在 0 – 100 的数字中,获取可以整除2的数字

def func(data):
  if data%2 == 0:
    return data
  else:
    return False

L = list(range(100))

res = list(pool.map(func, L)) 

多线程处理后会返回一个对象,可以转换为 list 的形式方便处理,所有的返回结果都会保持在list中,如果函数没有返回值,则会默认返回 None

res = [x for x in res if x != False]
print(res)

处理返回的结果,去除False值,然后打印结果

[2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 90, 92, 94, 96, 98]

评论已关闭。