返回顶部
首页 > 资讯 > 后端开发 > Python >Python队列的使用方法有哪些
  • 408
分享到

Python队列的使用方法有哪些

Python 2023-05-14 21:05:09 408人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

python中使用到的队列模块大致有三个:1、from queue import Queue此模块适用于线程间通信,但不能用于进程间通信。示例代码1: 【注意:此时代码存在错误!!!】import time import threading

python中使用到的队列模块大致有三个:

1、from queue import Queue

此模块适用于线程间通信,但不能用于进程间通信。

示例代码1: 【注意:此时代码存在错误!!!】

import time
import threading
from queue import Queue
def task_func():
    global queue
    while queue.qsize() > 0:
        x = queue.get()
        print(f"num: {x}")
        time.sleep(0.1)
def producer_data():
    global queue
    for i in range(100):
        queue.put(i)
        time.sleep(0.1)
if __name__ == '__main__':
    queue = Queue()
    producer_thread = threading.Thread(target=producer_data)
    producer_thread.start()
    thread_list = []
    for i in range(5):
        thread = threading.Thread(target=task_func)
        thread.start()
        thread_list.append(thread)
    for thread in thread_list:
        thread.join()
    print("主程序执行结束!")

注意:上述写法:

    while queue.qsize() > 0:
        x = queue.get()

当生产者速度没有消费者速度快时,上述消费者代码会提前结束,导致生产者的速度不能消费。

    while True:
        x = queue.get()

这种写法也存在问题,此时消费者队列会一直监听生产者队列是否有数据,导致线程一直处于阻塞状态,程序会一直阻塞不会停止,严重浪费系统资源。如果使用apscheduler等定时任务的库的话,会导致定时任务无法启动。

其实queue队列中的put()或者get()方法中都提供了timeout参数,利用这个参数可以有效解决上述消除不能消费和线程一直阻塞问题。

示例代码2:

import time
import threading
from queue import Queue
def task_func():
    global queue
    while True:
        x = queue.get(timeout=10)
        print(f"num: {x}")
def producer_data():
    global queue
    for i in range(100):
        queue.put(i)
        time.sleep(0.1)
if __name__ == '__main__':
    queue = Queue()
    producer_thread = threading.Thread(target=producer_data)
    producer_thread.start()
    thread_list = []
    for i in range(5):
        thread = threading.Thread(target=task_func)
        thread.start()
        thread_list.append(thread)
    for thread in thread_list:
        thread.join()
    print("主程序执行结束!")

运行结果:

Python队列的使用方法有哪些

根据不同的情境,可以根据实际情况设置timeout的值。如果使用定时任务,使用timeout是可以的,不会使程序抛异常停止的。

2、from multiprocessing import Queue

此模块用于对进程,但是不能用于进程池

示例代码:

import time
from multiprocessing import Process, Queue
import queue
def producer(queue):
    queue.put("a")
    time.sleep(2)
def consumer(queue):
    time.sleep(2)
    data = queue.get()
    print(data)
if __name__ == "__main__":
    # queue = queue.Queue()
    queue = Queue()
    my_producer = Process(target=producer, args=(queue, ))
    my_consumer = Process(target=consumer, args=(queue, ))
    my_producer.start()
    my_consumer.start()
    my_producer.join()
    my_consumer.join()
# 使用queue模块的Queue()会报错
# 使用multiprocessing中的Queue(),正确输出a

运行结果:

Python队列的使用方法有哪些

3、from multiprocessing import Manager

示例代码:

import time
from multiprocessing import Process, Queue, Pool, Manager
def producer(queue):
    queue.put("a")
    time.sleep(2)
def consumer(queue):
    time.sleep(2)
    data = queue.get()
    print(data)
if __name__ == "__main__":
    # queue = Queue()
    queue = Manager().Queue()
    pool = Pool()
    # pool中的进程间通信需要使用Manager
    pool.apply_async(producer, args=(queue, ))
    pool.apply_async(consumer, args=(queue, ))
    pool.close()
    pool.join()

运行结果:

Python队列的使用方法有哪些

以上就是Python队列的使用方法有哪些的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: Python队列的使用方法有哪些

本文链接: https://lsjlt.com/news/206167.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python队列的使用方法有哪些
    python中使用到的队列模块大致有三个:1、from queue import Queue此模块适用于线程间通信,但不能用于进程间通信。示例代码1: 【注意:此时代码存在错误!!!】import time import threading...
    99+
    2023-05-14
    Python
  • c++队列的用法有哪些
    C++中队列的用法有以下几种: 声明队列:使用std::queue模板类声明队列对象。 #include <queue&g...
    99+
    2024-02-29
    c++
  • 队列实现栈的方法有哪些
    本篇内容介绍了“队列实现栈的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!先来回顾一下栈(Sta...
    99+
    2024-04-02
  • Python队列的练习题有哪些
    这篇文章主要为大家展示了“Python队列的练习题有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python队列的练习题有哪些”这篇文章吧。1. 使用两个栈实现一个队列[问题] 给定两个栈...
    99+
    2023-06-29
  • java的队列有哪些
    java中的队列有:1.ArrayBlockingQueue,基于数组结构的有界阻塞队列;2.LinkedBlockingQueue,基于链表结构的阻塞队列;3.PriorityBlockingQueue,具有优先级的无限阻塞队列;4.Sy...
    99+
    2024-04-02
  • java队列queue使用场景有哪些
    Java队列(Queue)是一种数据结构,遵循先进先出(FIFO)原则。它可以在队尾插入元素,在队头删除元素。以下是一些Java队列...
    99+
    2023-08-18
    java
  • java队列有哪些
    java中的队列有:1.阻塞队列,支持两个附加操作的队列;2.非阻塞队列,一个线程的失败或挂起不会影响其他线程的失败或挂起;java中的队列有以下两种阻塞队列java中阻塞队列是一个支持两个附加操作的队列,当队列为空时,获取元素的线程会等待...
    99+
    2024-04-02
  • Python中的队列和栈的实现方式和使用场景有哪些?
    Python中的队列和栈的实现方式和使用场景有哪些?队列和栈是数据结构中常用的两种数据类型,它们分别具有不同的特性和使用场景。Python提供了多种实现方式来创建和操作队列(Queue)和栈(Stack)的数据结构。队列的实现方式:1.1 ...
    99+
    2023-10-22
    队列 实现方式 使用场景
  • Python列表的方法有哪些
    这篇文章主要介绍“Python列表的方法有哪些”,在日常操作中,相信很多人在Python列表的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python列表的方法有哪些”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-16
  • Python的列表方法有哪些
    本文小编为大家详细介绍“Python的列表方法有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python的列表方法有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。列表更多的方法index():返回指定...
    99+
    2023-06-29
  • Python列表的应用方法有哪些
    今天小编给大家分享一下Python列表的应用方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Python 集合(数组...
    99+
    2023-07-06
  • Python中的堆和优先队列的使用场景有哪些?
    Python中的堆和优先队列的使用场景有哪些?堆是一种特殊的二叉树结构,常用于高效地维护一个动态的集合。Python中的heapq模块提供了堆的实现,可以方便地进行堆的操作。优先队列也是一种特殊的数据结构,不同于普通的队列,它的每个元素都有...
    99+
    2023-10-28
    使用场景 优先队列
  • python消息队列框架有哪些
    python中的消息队列框架有RabbitMQ、Redis、ZeroMQ、Jafka几种RabbitMQRabbitMQ是一个使用Erlang编写的开源消息队列框架,RabbitMQ支持AMQP、XMPP、SMTP、STOMP等协议,常用于...
    99+
    2024-04-02
  • 消息队列的作用有哪些
    本篇内容介绍了“消息队列的作用有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!流量削峰消息队列,其实并...
    99+
    2024-04-02
  • Python中的队列和栈的应用场景有哪些?
    Python中的队列和栈的应用场景有哪些?队列和栈是计算机科学中常用的数据结构,它们可以有效地解决许多实际问题。在Python中,我们可以使用内置的Queue和collections模块来实现队列和栈。接下来,本文将介绍队列和栈的定义、特性...
    99+
    2023-10-22
    网页爬虫 队列: 广度优先搜索(BFS) 计算机作业调度 栈:
  • web开发中队列的写法有哪些
    队列写法有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言栈和队列是一对好兄弟,前面我们介...
    99+
    2024-04-02
  • python有序队列怎么使用
    在Python中,你可以使用queue模块中的Queue类来实现有序队列的操作。Queue类是一个线程安全的队列,提供了一系列的方法...
    99+
    2024-02-29
    python
  • 合并Python列表的方法有哪些
    本篇内容介绍了“合并Python列表的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!我喜欢12这个数字,因为有太多的事情与12有关...
    99+
    2023-06-15
  • python创建列表的方法有哪些
    本篇内容主要讲解“python创建列表的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python创建列表的方法有哪些”吧!1、使用[]包裹列表中,每一个元素都是通过逗号、分割的。元素...
    99+
    2023-06-20
  • python列表的操作方法有哪些
    这篇“python列表的操作方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python列表的操作方法有哪些”文章吧...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作