python 多线程编程(三)
2012-03-09 17:38
399 查看
threading模块是python线程很重要的一个模块,可以简化很多线程的操作,下面是个三个函数计算,可以看到单线程的情况下消耗了5秒钟,多线程的情况下只用了2秒多一点:
运行结果:
MyThread的代码如下:
''' Created on 2012-3-9 @author: Administrator ''' #!/usr/bin/env python from MyThread import MyThread from time import ctime,sleep def fib(x): sleep(0.005) if x<2: return 1 return (fib(x-2)+fib(x-1)) def fac(x): sleep(0.1) if x<2: return 1 return (x*fac(x-1)) def sum(x): sleep(0.1) if x<2: return 1 return (x+sum(x-1)) funcs=[fib,fac,sum] n=12 def main(): nfuncs = range(len(funcs)) print '*** single thread' for i in nfuncs: print 'starting',funcs[i].__name__,'at:',\ ctime() print funcs[i](n) print funcs[i].__name__,'done at:',\ ctime() print '\n*** multiple thread' threads=[] for i in nfuncs: t=MyThread(funcs[i],(n,),funcs[i].__name__) threads.append(t) for i in nfuncs: threads[i].start() for i in nfuncs: threads[i].join() print threads[i].getResult() print 'all done' if __name__=='__main__': main()
运行结果:
*** single thread starting fib at: Fri Mar 09 17:38:03 2012 233 fib done at: Fri Mar 09 17:38:05 2012 starting fac at: Fri Mar 09 17:38:05 2012 479001600 fac done at: Fri Mar 09 17:38:06 2012 starting sum at: Fri Mar 09 17:38:06 2012 78 sum done at: Fri Mar 09 17:38:08 2012 *** multiple thread starting fib at: Fri Mar 09 17:38:08 2012 starting fac at: Fri Mar 09 17:38:08 2012 starting sum at: Fri Mar 09 17:38:08 2012 sumfac done at:done at: Fri Mar 09 17:38:09 2012Fri Mar 09 17:38:09 2012 fib done at: Fri Mar 09 17:38:10 2012 233 479001600 78 all done
MyThread的代码如下:
''' Created on 2012-3-9 @author: Administrator ''' #!/usr/bin/env python import threading from time import ctime class MyThread(threading.Thread): def __init__(self,func,args,name=''): threading.Thread.__init__(self) self.name=name self.func=func self.args=args def getResult(self): return self.res def run(self): print 'starting',self.name,'at:',\ ctime() self.res=apply(self.func,self.args) print self.name,'done at:',\ ctime()
相关文章推荐
- python多线程编程
- python中多线程编程
- 在Python下尝试多线程编程
- python 多线程编程
- Python多线程编程(1): python对多线程的支持
- Python多线程编程(八):使用Event实现线程间通信
- Python threading多线程编程
- python多线程编程
- python中使用threading进行多线程编程 分类: python Module 2014-03-10 16:00 277人阅读 评论(0) 收藏
- python多线程编程(2): 线程的创建、启动、挂起和退出
- Python多线程编程
- Python学习之多线程编程
- python学习笔记——多线程编程
- python多线程编程(2): 线程的创建、启动、挂起和退出
- Python学习笔记18:Python多线程编程
- Python 多线程编程 (一)
- zt:python多线程编程
- Python多线程编程(2): 线程的创建、启动、挂起和退出
- python多线程编程(2): 线程的创建、启动、挂起和退出
- python中使用threading进行多线程编程