python队列中替换某元素_python – 检查元素是否已存在于队列中

本文介绍了如何在Python中创建一个自定义队列类,以检查元素是否存在并在队列中添加或替换元素。通过继承Queue类并覆写内部方法,实现了SetQueue和OrderedSetQueue,分别用于无序和有序地处理元素。同时,讨论了并发安全性问题,建议在多线程环境下使用队列时,应确保操作的原子性。
摘要由CSDN通过智能技术生成

无法迭代或以其他方式检查标准Queue类.

但是,它是为了扩展而构建的.

首先,如果你看一下source(从文档链接),你可以覆盖钩子方法_init,_qsize,_put和_get来改变实现.查看主类下面的子类,您可以看到它们是如何执行此操作的.

所以,一件容易的事就是用一个集替换deque实现:

class SetQueue(Queue.Queue):

def _init(self, maxsize):

self.queue = set()

def _put(self, item):

self.queue.add(item)

def _get(self):

return self.queue.pop()

(我没有实现_qsize,因为默认返回len(self.queue)没问题.)

现在您不必检查,只需将其添加到队列中,如果它已经存在,它将被忽略.

当然,这有不足之处,不再对队列进行排序.但是你可以通过使用OrderedSet(类似于集合中的OrderedDict)来解决这个问题.有一个recipe链接来自馆藏文档.一旦你有了:

class OrderedSetQueue(Queue.Queue):

def _init(self, maxsize):

self.queue = OrderedSet()

def _put(self, item):

self.queue.add(item)

def _get(self):

return self.queue.pop()

如果您确实希望能够检查队列中的值,可以为其添加一个方法:

class CheckableQueue(Queue.Queue): # or OrderedSetQueue

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值