Python(18)多线程编程
- Python线程和进程
- threading模块
Python线程和进程
进程是程序的一次执行。线程是运行在进程中的。
全局解释器锁
在Python设计之初就考虑到,在主循环中同时只有一个线程在执行。虽然Python解释器中可以运行多个线程,但是在任意时刻,只有一个线程在解释器中运行
threading模块
threading模块对象
threading模块对象 | 描述 | 备注 |
---|---|---|
Thread | 一个线程的执行对象 | |
Lock | 锁原语对象 | |
Rlock | 可重入锁对象 | |
Condition | 让一个线程停下来,等待其他线程满足某个条件 | |
Event | 多个线程可以等待某个时间发生,然后所有线程被激活 | |
Semaphore | 等候室,为等待锁的线程提供一个等候室的结构 | |
BoundedSemaphore | 同上 | |
Timer | 与Thread类似,等待一段时间后才开始运行 |
创建线程的一个例子:
import threading
import time
def loop(num, sec):
print 'loop',num,'star at:',time.ctime()
time.sleep(sec)
print 'loop',num,'done at:',time.ctime()
def main ():
t1 = threading.Thread(target=loop,args=(1,4))
t1.start()
t2 = threading.Thread(target=loop,args=(2,2))
t2.start()
if __name__ == '__main__':
main()
loop 1 star at: Wed Feb 14 11:06:52 2018
loop 2 star at: Wed Feb 14 11:06:52 2018
loop 2 done at: Wed Feb 14 11:06:54 2018
loop 1 done at: Wed Feb 14 11:06:56 2018