您的位置:首页 > 编程语言 > Python开发

关于python使用threadpool中的函数单个参数和多个参数用法举例

2017-05-16 17:06 891 查看
1.对单个元素的函数使用线程池:

# encoding:utf-8
__author__='xijun.gong'
import threadpool

def func(name):
print 'hi {}\n'.format(name)

if __name__ == '__main__':
data = ['xijun.gong', 'xijun', 'gxjun']
pool = threadpool.ThreadPool(5)
reqs = threadpool.makeRequests(func, data)
[pool.putRequest(req) for req in reqs]
pool.wait()


结果:

hi xijun.gong

hi xijun

hi gxjun

2.对于多个参数的情况使用方式:

# encoding:utf-8
__author__='xijun.gong'
import threadpool

def func(name):
print 'hi {}\n'.format(name)

def add(a,b):
print '{0}+{1}={2}'.format(a,b,(a+b))
if __name__ == '__main__':
data = [((index,i),None) for index,i in enumerate(range(1,10,2))]#(index,i)也可以写成[index,i]
pool = threadpool.ThreadPool(5)
reqs = threadpool.makeRequests(add, data)
[pool.putRequest(req) for req in reqs]
pool.wait()


结果:

0+1=1
1+3=4
3+7=10
2+5=7
4+9=13

3.如果我们想不安参数顺序赋值,可以使用这种方式:

# encoding:utf-8
__author__='xijun.gong'
import threadpool

def func(name):
print 'hi {}\n'.format(name)

def add(a,b):
print '{0}+{1}={2}'.format(a,b,(a+b))
if __name__ == '__main__':
data = [(None,{'b':index,'a':i}) for index,i in enumerate(range(1,10,2))]
pool = threadpool.ThreadPool(5)
reqs = threadpool.makeRequests(add, data)
[pool.putRequest(req) for req in reqs]
pool.wait()


结果:

1+0=1
3+1=4
5+2=7
7+3=10
9+4=13
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: