zoukankan      html  css  js  c++  java
  • 关于队列queue

    1.在多线程和多进程中都有queue。调用方式不同,使用方式一致:

    线程中:

    import queue
    q = queue.Queue(maxsize = 2)

    进程中:

    from multiprocessing import Process, Queue
    q = Queue()

    import queue
    q = queue.Queue(maxsize = 2)
    q.put(2)
    q.put(4)
    q.put(8,block=0) # 默认block为1 即满了就阻塞等待空位,改为0 会full报错
    q.get() # get同理 拿不出来block为True时就阻塞
    '''
    Python Queue模块有三种队列及构造函数:
    1、Python Queue模块的FIFO队列先进先出。 class queue.Queue(maxsize)
    2、LIFO类似于堆,即先进后出。 class queue.LifoQueue(maxsize)
    3、还有一种是优先级队列级别越低越先出来。 class queue.PriorityQueue(maxsize)
    ************一些方法
    q.qsize() 返回队列的大小
    q.empty() 如果队列为空,返回True,反之False
    q.full() 如果队列满了,返回True,反之False
    q.full 与 maxsize 大小对应
    q.get([block[, timeout]]) 获取队列,timeout等待时间
    q.get_nowait() 相当q.get(False)
    非阻塞 q.put(item) 写入队列,timeout等待时间
    q.put_nowait(item) 相当q.put(item, False)
    q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
    q.join() 实际上意味着等到队列为空,再执行别的操作
    '''

  • 相关阅读:
    [POI2011]Lightning Conductor
    [NOI2009]诗人小G

    公告&留言板
    联合省选 2020 题解
    年末时的一些思维碎屑
    RE:ゼロから始める AFO 生活
    退役前的做题记录6.0
    2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解
    300iq Contest 1 简要题解
  • 原文地址:https://www.cnblogs.com/khal-Cgg/p/5973753.html
Copyright © 2011-2022 走看看