python: 多线程

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和处理。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值