*我们这里先讲一下进程中的队列,下一篇文章讲进程的通信用队列Queue
import os
from multiprocessing import process,Queue
#设置队列的长度
q =Queue(5)
#为队列赋值
q.put(2)
q.put(1)
q.put(3 )
q.put(4 )
q.put(5)
#如果设定了范围是5个,当赋值第六个是时候,就会一直等待,我们这里用timeout=2设定为等待两秒,两秒之后会给你报错出红色,
q.put(6 ,timeout = 2)
在这里插入图片描述
#我们这里设置一下取值范围,如果队列满了,也就是复合q.full(),就输出(the queue have finished),而不会报错出红色,
if q.full():
print('the queue have finished')
else:
q.put(22)
#这里的是从队列中取值,限定时间是1秒,阻止一直取值而没有值的时候一直等待,这里没有值的时候,只等待一秒,然后爆红出错
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
*如果能直接看懂原代码,就直接看完整的,不用看我的解释了,附原代码,
import os
from multiprocessing import process,Queue
#设置队列的长度
q =Queue(5)
#为队列赋值
q.put(2)
q.put(1)
q.put(3 )
q.put(4 )
q.put(5)
#如果设定了范围是5个,当赋值第六个是时候,就会一直等待,我们这里用timeout=2设定为等待两秒,两秒之后会给你报错出红色,
#q.put(6 ,timeout = 2)
#我们这里设置一下取值范围,如果队列满了,也就是复合q.full(),就输出(the queue have finished),而不会报错出红色,
if q.full():
print('the queue have finished')
else:
q.put(22)
#这里的是从队列中取值,限定时间是1秒,阻止一直取值而没有值的时候一直等待,这里没有值的时候,只等待一秒,然后爆红出错
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
print(q.get(timeout=1))
#print(q.get(timeout=1))*