python的多线程编程 --- thread模块
2015-06-23 12:07
941 查看
1、使用thread模块(不推荐)
常用函数:
‘start_new_thread(function,args,kwargs=None)’:创建一个新的线程,并运行’function(args)’
‘allocate_lock()’: 创建锁对象 Lock object
‘exit()’: 提示线程退出
Lock的函数:
‘acquire(wait=None)’: 获取lock对象或等待wait时间
‘locked()’ 获得lock返回true,否则返回false
‘release’ :释放lock
例子1:
注意:1、虽然loop0不接受参数,但’start_new_thread’中的空tuple不能够省略;
2、使用sleep,因为在主线程创建线程后,主线程会继续运行直到退出,同时杀死所有的子线程,而不做任何的检查,这也是不推荐使用thread模块的原因之一。
例子2:
多个线程间可以通过共享lock,防止资源访问的冲突
常用函数:
‘start_new_thread(function,args,kwargs=None)’:创建一个新的线程,并运行’function(args)’
‘allocate_lock()’: 创建锁对象 Lock object
‘exit()’: 提示线程退出
Lock的函数:
‘acquire(wait=None)’: 获取lock对象或等待wait时间
‘locked()’ 获得lock返回true,否则返回false
‘release’ :释放lock
例子1:
import thread from time import sleep,ctime def loop0(): print 'start loop 0" def main(): thread.start_new_thread(loop0,()) sleep(6) if __name__=='__main__': main()
注意:1、虽然loop0不接受参数,但’start_new_thread’中的空tuple不能够省略;
2、使用sleep,因为在主线程创建线程后,主线程会继续运行直到退出,同时杀死所有的子线程,而不做任何的检查,这也是不推荐使用thread模块的原因之一。
例子2:
import thread from time import sleep,ctime loops=[4,2] def loop(nloop,nsec,lock): print 'start loop',nloop,'at:',ctime() lock.release() def main(): print 'starting' locks=[] nloops = range(len(loops)) for i in nloops: lock=thread.allocate_lock() lock.acquire() locks.append(lock) for i in nloops: thread.start_new_thread(loop,(i,loops[i],locks[i]) for i in nloops: while locks[i].locked(): pass print 'all done' if __name__=='__main__': main()
多个线程间可以通过共享lock,防止资源访问的冲突
相关文章推荐
- sublime3安装python插件 -- SublimeCodeIntel
- python中的深拷贝和浅拷贝理解
- Python 被导入模块多次被加载的问题(基于python的import机制)
- python的requests初步使用
- 基于Flask框架的Python web程序的开发实战 <一> 环境搭建
- Python学习笔记一:数据类型与基本操作
- 4-python学习——数据操作
- 3-python学习——变量
- 2-python学习——hello world
- [转] Python风格规范
- 1 python学习——python环境配置
- 端午节前一周周记
- Python 函数式编程学习
- Python中线程编程之threading模块的使用详解
- Python os模块常用方法1
- python
- python3.4学习笔记(三) idle 清屏扩展插件
- python3.4学习笔记(二) 类型判断,异常处理,终止程序
- python特殊函数(id, dir, type, isinstance, issubclass, is)
- web python -- WSGI接口POST请求