一、安装与简介

pip install threadpool

pool = ThreadPool(poolsize)
requests = makeRequests(some_callable, list_of_args, callback)
[pool.putRequest(req) for req in requests]
pool.wait()

第一行定义了一个线程池,表示最多可以创建poolsize这么多线程;

第二行是调用makeRequests创建了要开启多线程的函数,以及函数相关参数和回调函数,其中回调函数可以不写,default是无,也就是说makeRequests只需要2个参数就可以运行;

第三行用法比较奇怪,是将所有要运行多线程的请求扔进线程池,[pool.putRequest(req) for req in requests]等同于

  for req in requests:

     pool.putRequest(req)

第四行是等待所有的线程完成工作后退出。

二、代码实例

import time
def sayhello(str):
print "Hello ",str
time.sleep() name_list =['xiaozi','aa','bb','cc']
start_time = time.time()
for i in range(len(name_list)):
sayhello(name_list[i])
print '%d second'% (time.time()-start_time)

改用线程池代码,花费时间更少,更效率

import time
import threadpool
def sayhello(str):
print "Hello ",str
time.sleep() name_list =['xiaozi','aa','bb','cc']
start_time = time.time()
pool = threadpool.ThreadPool()
requests = threadpool.makeRequests(sayhello, name_list)
[pool.putRequest(req) for req in requests]
pool.wait()
print '%d second'% (time.time()-start_time)

当函数有多个参数的情况,函数调用时第一个解包list,第二个解包dict,所以可以这样:

def hello(m, n, o):
""""""
print "m = %s, n = %s, o = %s"%(m, n, o) if __name__ == '__main__': # 方法1
lst_vars_1 = ['', '', '']
lst_vars_2 = ['', '', '']
func_var = [(lst_vars_1, None), (lst_vars_2, None)]
# 方法2
dict_vars_1 = {'m':'', 'n':'', 'o':''}
dict_vars_2 = {'m':'', 'n':'', 'o':''}
func_var = [(None, dict_vars_1), (None, dict_vars_2)] pool = threadpool.ThreadPool()
requests = threadpool.makeRequests(hello, func_var)
[pool.putRequest(req) for req in requests]
pool.wait()

需要把所传入的参数进行转换,然后带人线程池。

def getuserdic():
username_list=['xiaozi','administrator']
password_list=['root','','abc123!','','password','root']
userlist = [] for username in username_list: user =username.rstrip()
for password in password_list:
pwd = password.rstrip()
userdic ={}
userdic['user']=user
userdic['pwd'] = pwd
tmp=(None,userdic)
userlist.append(tmp)
return userlist

最后

欢迎关注个人微信公众号:Bypass--,每周原创一篇技术干货。 

最新文章

  1. cinnamon桌面安装在其他目录下
  2. Android初体验
  3. WPF窗体禁用最大化按钮
  4. osgi与webservice
  5. Facebook 正式开源其大数据查询引擎 Presto
  6. Datamatrix码
  7. (大数据工程师学习路径)第二步 Vim编辑器----Vim快速入门
  8. C# 文件上传(可以多文件上传)
  9. [JavaScript]ECMA-6 箭头函数
  10. python-数据类型之题型
  11. 安装oracle [INS-32025] 所选安装与指定 Oracle 主目录中已安装的软件冲突” 的问题
  12. [原创]K8Cscan插件之存活主机扫描
  13. HDFS简单测试
  14. php多进程、IPC和事件驱动
  15. 连接mysql && ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)
  16. (转)mblog解读(一)
  17. Fiddler抓包使用教程-会话图标
  18. MSSQL数据库高版本迁移到低版本
  19. 手写redis客户端
  20. 菜鸟学Linux - 变量基本规则

热门文章

  1. Maven 从svn下载后,pom.xml报错解决方案
  2. C++模拟C#事件委托机制(一)
  3. HttpRequestUtil
  4. linux下用eclipse + GDBserver + JLINK 在线调试(ARM11)
  5. Visual Studio 不生成.vshost.exe和.pdb文件的方法【转】
  6. Command Pattern
  7. 通过JavaScript改变HTML样式
  8. windows10(x64)+Qt+opencv配置及测试
  9. MySQL中DATETIME、DATE和TIMESTAMP类型的区别
  10. 2016 - 1 - 25 第三方网络框架 AFN的简单使用