python习题:【多线程】有100个数据,启动5个线程,每个线程分20个数据,怎么把这20个数据分别传给每个线程。

# 有100个数据,启动5个线程,每个线程分20个数据,怎么把这20个数据分别传给每个线程。
# 每次传下标是【0:20】【20:40】【40:60】【60:80】【80:100】

import threading

def say(lis):
for i in lis:
print(i)

res = list(range(10))

for i in range(5):
threading.Thread(target=say,args=(res[i*20:(i+1)*20],))


用线程池实现
# 线程池:放线程的池子
import threadpool

def say(num):
print(num)

res = list(range(100))
pool = threadpool.ThreadPool(20) #定义线程池的大小

reqs=threadpool.makeRequests(say,res) #生成线程要执行的所有线程,第一个参数是函数,第二个参数是数据,这样就可以算出来每个线程分几个数据

# for req in reqs:
# pool.putRequest(req) # 实际才去执行的
[pool.putRequest(req) for req in reqs] # 实际才去执行的

pool.wait()#等待 其他线程执行结束

posted on 2018-03-11 09:46  爱睡觉的加菲猫  阅读(731)  评论(0编辑  收藏  举报

导航