知行编程网知行编程网  2022-12-02 14:00 知行编程网 隐藏边栏  14 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于Python如何实现队列的同步实现的相关知识,希望可以帮到处于编程学习途中的小伙伴


Python如何实现队列的同步


队列

q = Queue.Queue(maxsize = 10) 创建一个“队列”对象。 Queue.Queue 类是队列的同步实现。队列长度可能有也可能没有限制。队列长度可以通过 Queue 构造函数的可选参数 maxsize 来设置。如果 maxsize 小于 1,则表示队列长度。

q.put() 方法在队列的末尾插入一个项目。 put()有两个参数,第一个是必填项,是插入项的值;第二个块是可选参数,默认值为 1。如果队列当前为空且块为 1,则 put() 方法会导致调用线程暂停,直到释放数据单元。如果 block 为 0,则 put 方法将抛出 Full 异常。

q.get([block[, timeout]]) 方法从队列头部移除并返回一个项目。可选参数是 block,默认为 True。如果队列为空且块为 True,则 get() 会导致调用线程暂停,直到有可用项为止。如果队列为空且block为False,队列会抛出Empty异常和超时等待时间。

q.qsize() 返回队列的大小

q.empty() 如果队列为空,返回True,反之False

q.full() 如果队列满了,返回True,反之False

q.full 与 maxsize 大小对应

q.get_nowait() 相当q.get(False)

q.put_nowait(item) 相当q.put(item, False)

q.task_done() 完成一项工作后,q.task_done()函数向队列发送一个任务完成的信号

q.join() 实际上意味着等到队列为空,再执行别的操作

import queue
d = queue.Queue()
d.put('1')
d.put('2')
d.put('3')
print(d.get())
print(d.get())
print(d.get())
print(d.get())
print(d.get(0))

运行结果:

1
2
3

报错:

queue.Empty

线程操作列表是不安全的。

import threading, time
li = [1, 2, 3, 4, 5]
def pri():
    while li:
        a = li [-1]
        print(a)
        time.sleep(1)
        try:
            li.remove(a)
        except:
            print('-----', a)
t1 = threading.Thread(target=pri, args=())
t1.start()
t2 = threading.Thread(target=pri, args=())
t2.start()

运行结果:

5
5
4
----- 5
4
3
----- 4
3
2
----- 3
2
1
----- 2
1
----- 1
import threading, queue
from time import sleep
from random import randint
class Production(threading.Thread):
    def run(self):
        while True:
            r = randint(0, 100)
            q.put(r)
            print("生产出来 %s 号包子" %r)
            sleep(1)
class Proces(threading.Thread):
    def run(self):
        while True:
            re = q.get()
            print('吃掉 %s号包子' %re)
if __name__ == '__main__':
    q = queue.Queue(10)
    threads = [Production(),Production(),Production(),Proces()]
    for t in threads:
        t.start()

运行结果:

生产出来 94 号包子
生产出来 13 号包子
生产出来 79 号包子
吃掉 94号包子
吃掉 13号包子
吃掉 79号包子
生产出来 43 号包子
吃掉 43号包子
生产出来 32 号包子
吃掉 32号包子
......

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享