python中的多线程模块:
thread:提供了基本的线程的锁和支持,不推荐使用。
threading:更高级的线程管理功能。
Queue:用于线程之间共享数据的队列。
###################################################
thread模块:
thread模块的内建函数:
start_new_thread(function, args[, kwargs]):创建一个新线程,调用线程函数function,args是指定参数,kwargs是可选参数。
exit():退出线程
allocate_lock():分配一个LockType类型的锁对象
LockType类的方法:
acquire([wait]):尝试获取锁对象
locked():获取锁对象返回True
release():释放锁
###################################################
threading模块:
threading模块的类:
Thread:表示一个线程执行的对象
Timer:与Thread类似,只是要等待一段时间后才开始运行
Lock:锁原语对象
RLock:可重入锁对象
Condition:条件变量,能让一个线程停下来,等待其它线程满足某个条件
Event:通用的条件变量,多个线程可以等待某个时间的发生,在时间发生后所有线程都被激活
Semaphore:为等待的线程提供一个结构
BoundedSemaphore:与Semaphore类似,只是不允许超过初始值
class Thread(_Verbose)
__init__(self, group=None, target=None, name=None, args=(), kwargs=None, verbose=None)
target是线程函数通过run方法调用,name是线程名字,args是线程函数指定参数,kwargs是可选参数。
Thread类的方法:
start():开始线程的执行,调用run方法。
run():定义线程的功能的函数
join(self, timeout=None):程序挂起,直到线程结束
getName():返回线程的名字
setName(name):设置线程的名字
isAlive():表示这个线程是否还在运行中
isDaemon():返回线程的daemon标志
setDaemon(daemonic):把线程的daemon值设置为daemonic
三种方法创建线程:
1.创建Thread实例,传一个函数
2.创建Thread实例,传一个可调用类对象
3.从Thread派生一个子类,创建这个子类的实例
###################################################
Queue模块:
class Queue
__init__(self, maxsize=0)
创建一个maxsize大小的队列。
Queue类的方法:
get(self, block=True, timeout=None):从队列中取一个对象,函数会一直阻塞到队列中有对象为止
put(self, item, block=True, timeout=None):把item放到队列中,函数会一直阻塞到队列中有空间为止
qsize():返回队列大小
full():如果队列已满返回True
empty():如果队列为空返回True
join():阻塞直到队列中所有item都被get和处理。