import queue,time,threading
q=queue.Queue(5)#队列最多只能放5个
def Producer(name):
count=1
while True:
print("生产第[%s]个包子"%count)
q.put(count)
count+=1
time.sleep(1.5)
def Consumer(name):
while True:
print("%s 取了第[%s]包子,并且把它吃了"%(name,q.get()))
p=threading.Thread(target=Producer,args=('hunter',))
c=threading.Thread(target=Consumer,args=('James',))
c1=threading.Thread(target=Consumer,args=('Jack',))
p.start()
c.start()
c1.start()
队列:
它和列表的区别就是,数据从队列中拿走后,数据就不存在队列中了,列表就不一样数据拿走了,列表中的数据还是存在, 默认的是先进先出, 也有优先级和后进先出
两个方法 一个是put 往队列里面添加数据,一个是get从队列里面取出数据
import queue q=queue.Queue() q.put(1)#往队列里面添加数据 q.put(2) print(q.get())#从队列里面取出数据 print(q.qsize())#队列里面有多少数据。 如果队列的数据已经取完了。就会造成阻塞
深度队列
from collections import deque
deque.append()#从后面放数据
deque.appendleft()#从前面放数据
deque.pop()#从后面取数据
deque.popleft()#从前面取数据
浙公网安备 33010602011771号