一、队列
IPC(Inter-Process Communication)进程之间通信
队列先进先出
Queue()实例化是可以传一个参数代表队列上限,如果不传或传负数都表示队列没有限制。
当队列容量不够时会阻塞
Queue可以创建共享的进程队列,Queue是多进程安全的队列,可以使用Queue实现多进程之间的数据传递
二、常用属性和方法
Queue([maxsize])
创建共享的进程队列。
参数 :maxsize是队列中允许的最大项数。如果省略此参数,则无大小限制。
底层队列使用管道和锁定实现。
q.get( [ block [ ,timeout ] ] )
返回q中的一个项目。如果q为空,此方法将阻塞,直到队列中有项目可用为止。
block用于控制阻塞行为,默认为True阻塞进程. 如果设置为False,不阻塞但将引发Queue.Empty异常(定义在Queue模块中)。
timeout是可选超时时间,用在阻塞模式中。如果在制定的时间间隔内没有项目变为可用,将引发Queue.Empty异常。
q.get_nowait( )
同q.get(False)方法。
q.put(item [, block [,timeout ] ] )
将item放入队列。如果队列已满,此方法将阻塞至有空间可用为止。
block控制阻塞行为,默认为True阻塞。如果设置为False,不阻塞但将引发Queue.Empty异常(定义在Queue库模块中)。
timeout指定在阻塞模式中等待可用空间的时间长短。超时后将引发Queue.Full异常。
q.pu