最近在做一个东西的时候发现需要用到循环队列,实现先进先出(FIFO),不断往里面添加数据,当达到某个限定值时,最先进去的出去,然后再添加。之后需要对队列里面的内容进行一个筛选,作其他处理。首先我想到了python的Queue模块,先简单的介绍一下,具体的可以参考Queue

一、Queue模块

Python queue模块有三种队列及构造函数:
  1、Python queue模块的FIFO队列先进先出。     class queue.queue(maxsize)
  2、LIFO类似于堆栈,即先进后出。                         class queue.Lifoqueue(maxsize)
  3、还有一种是优先级队列级别越低越先出来。    class queue.Priorityqueue(maxsize)

此包中的常用方法(q =queue.queue()):
  q.qsize() 返回队列的大小

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

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

  q.get(block=Truetimeout=None]) 从队列中返回并删除一个元素,timeout等待时间

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

  q.put(itemblock=Truetimeout=None)非阻塞 q.put(item) 写入队列,timeout等待时间

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

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

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

  

  这里引入Queue模块就可以实现FIFO了,当我要提取队列里面的数据的时候,我得利用get()方法先把数据提取出来,然后存入一个新的数组,由于我要隔一段时间对里面的数据进行提取,而get()方法提取的时候会删除对应的元素,这样有点儿不方便。因此我自己写了一个类(写的不好的地方,大神们可以告诉我,不喜勿喷hh)

二、自定义一个类(circular_queue.py)

# 定义队列类
class MyQueue(object):
def __init__(self, size):
self.size = size # 定义队列长度
self.queue = [] # 存储队列 列表 def __str__(self):
# 返回对象的字符串表达式,方便查看
return str(self.queue) def inQueue(self, n):
# 入队
if self.isFull():
return -1
self.queue.append(n) # 列表末尾添加新的对象 def outQueue(self):
# 出队
if self.isEmpty():
return -1
firstelement = self.queue[0] # 删除队头元素
self.queue.remove(firstelement) # 删除队操作
return firstelement def delete(self, n):
# 删除某元素
element = self.queue[n]
self.queue.remove(element) def inPut(self, n, m):
# 插入某元素 n代表列表当前的第n位元素 m代表传入的值
self.queue[n] = m def getSize(self):
# 获取当前长度
return len(self.queue) def getnumber(self, n):
# 获取某个元素
element = self.queue[n]
return element def isEmpty(self):
# 判断是否为空
if len(self.queue) == 0:
return True
return False def isFull(self):
# 判断队列是否满
if len(self.queue) == self.size:
return True
return False

三、测试

在文件circular_queue.py中类的下头继续添加如下代码

queue = MyQueue(5)  # 定义一个大小为5的队列
for i in range(8):
# 先判断队列是否为满
if not queue.isFull():
queue.inQueue(i)
else:
# 先出队再添加
queue.outQueue()
queue.inQueue(i)
print(queue)

运行结果如下

  可以看出已经实现了,当然你也可以试试其他几种方法,比如提取元素,获取队列大小等等。接下来就可以像操作列表对元素进行提取,并且不会删除元素。

for i in range(queue.getSize()):
item =queue.getnumber(i)
print(item)

  当然也可以把circular_queue。py文件单独保存,然后到其他文件中引入,放入同一文件夹下,新建test.py,然后运行试试:

from circular_queue import *
import time def fun2(num):
num += 1
return num def fun1(num, res):
while True:
num = fun2(num)
# 先判断队列是否为满
if not queue.isFull():
queue.inQueue([num, res])
else:
# 先出队再添加
queue.outQueue()
queue.inQueue([num, res])
print(queue)
time.sleep(2) if __name__ == "__main__":
queue = MyQueue(5)
fun1(0, '-aaa-')

python 循环队列的实现的更多相关文章

  1. 数据结构-循环队列(Python实现)

    今天我们来到了循环队列这一节,之前的文章中,我介绍过了用python自带的列表来实现队列,这是最简单的实现方法. 但是,我们都知道,在列表中删除第一个元素和删除最后一个元素花费的时间代价是不一样的,删 ...

  2. [py]约瑟夫问题-循环队列

    约瑟夫问题(历史战争问题) 直观理解 老外视频讲解 模拟器演示 约瑟夫问题 数学姥公众号 讲的最清楚 背景及,推倒过程讲解得很清晰,旨在提高人们对数据的兴趣 简单说下: 几个人围成一圈(循环队列), ...

  3. Python消息队列工具 Python-rq 中文教程

    原创文章,作者:Damon付,如若转载,请注明出处:<Python消息队列工具 Python-rq 中文教程>http://www.tiangr.com/python-xiao-xi-du ...

  4. Python 用队列实现多线程并发

    # Python queue队列,实现并发,在网站多线程推荐最后也一个例子,比这货简单,但是不够规范 # encoding: utf-8 __author__ = 'yeayee.com' # 由本站 ...

  5. C++数组实现的循环队列

    #include<iostream> #include <string> /* 功能:数组实现的循环队列,C++实现,学习参考 */ using namespace std; ...

  6. Python循环语句

    1.Python循环类型 1.while循环:在某条件下,循环执行某段程序 a. while语句有两个重要命令:continue,break来跳出循环. continue用来跳出该次循环 break用 ...

  7. C ~ 链式队列与循环队列

          此处的链式与循环队列可以应用于BFS和树的层序遍历.下面是对其结构和基本操作的程序描述. 1.循环队列 解决循环队列的队空和队满的方法: [1].增加一个参数count,用来记录数组中当前 ...

  8. 数据结构算法C语言实现(十二)--- 3.4循环队列&队列的顺序表示和实现

    一.简述 空队列的处理方法:1.另设一个标志位以区别队列是空还是满:2.少用一个元素空间,约定以队列头指针在队尾指针下一位置上作为队列呈满的状态的标志. 二.头文件 //3_4_part1.h /** ...

  9. 使用 JavaScript 实现基本队列、优先队列和循环队列

    1.基本队列的实现 基本队列的方法中,包含了 ①向队列(尾部)中添加元素(enqueue).②(从队列头部)删除元素(dequeue).③查看队列头部的元素(front).④查看队列是否为空(isEm ...

随机推荐

  1. TX失败策略2

    自从有了人类,就有了智慧和精神.但总有一些思想家跳出来说人定胜天的理论,这是一种严重的误导.人类社会和自然界一样,遵守统一的自然定律.人就像不能改变物理定律一样改社会定律.更不可能因片面的社会现象遮盖 ...

  2. jQuery相同id元素 全部获取问题解决办法

    问题:今天在做页面链接的点击效果时,让部分a链接跳转到同一个地址,即使使用$().each()也同样无法获取所有相同id的值. 用以下方法只有第一个a链接点击可以正常跳转 例如: html代码: &l ...

  3. pandas numpy处理缺失值,none与nan比较

    原文链接:https://junjiecai.github.io/posts/2016/Oct/20/none_vs_nan/ 建议从这里下载这篇文章对应的.ipynb文件和相关资源.这样你就能在Ju ...

  4. 9.21 form 和Ajax详解

    form 表单 参考连接  : http://www.cnblogs.com/liwenzhou/p/8747872.html

  5. Jmeter与Jenkins结合进行Web接口测试

    纯通过Jmeter的界面进行Web的接口测试,效率低下.为此将Jmeter的接口测试与Jenkins联合,实现持续集成.配置完成后,只需修改运行的Jmeter脚本即可,运行结束后测试结果发送到指定邮箱 ...

  6. 树形DP总结,持续更新

    自己做了动态规划的题目已经有了一个月,但是成效甚微,所以来总结一下动态规划,希望自己能够温故知新.这个博客是关于树形dp的,动态规划的一类题目. 首先从最简单的树形DP入手,树形DP顾名思义就是一棵树 ...

  7. 计蒜客 30999 - Sum - [找规律+线性筛][2018ICPC南京网络预赛J题]

    题目链接:https://nanti.jisuanke.com/t/30999 样例输入258 样例输出814 题意: squarefree数是指不含有完全平方数( 1 除外)因子的数, 现在一个数字 ...

  8. 2018牛客网暑期ACM多校训练营(第五场) E - room - [最小费用最大流模板题]

    题目链接:https://www.nowcoder.com/acm/contest/143/E 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K ...

  9. HDU 2087 - 剪花布条 - [KMP算法]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2087 Time Limit: 1000/1000 MS (Java/Others) Memory Li ...

  10. Spring的AOP编程

    1.手动实现AOP编程(代理模式) AOP是面向切面的编程,主要功能就是实现"业务代码"和辅助业务代码的"关注点代码"分离.在一个方法中,出了核心的业务代码,其 ...