每日日报

进程间通信

队列

  • 创建一个对队对象

    队列对象 = multiprocessing.Queue(容量)
    
    queue
    英 [kjuː]   美 [kjuː]  
    n.
    (人、汽车等的)队,行列;(储存的数据)队列
    v.
    (人、车等)排队等候;(使)排队;列队等待
    
  • 传送数据

    队列对象.put(数据)
    

    阻塞的情况:当队列已经被塞满数据时,就会阻塞。无法put放入数据。当队列中有空位置时,就会解阻塞。

  • 接收数据

    数据 = 队列对象.get()
    

    阻塞的情况:当队列空了,出不了数据了,就会阻塞。直到队列中有新数据时,会解阻塞。

  • 接收数据,且不等待

    数据 = 队列对象.get_nowait()
    

    如果队列中有数据,可以获得,如果队列中无数据,那就报错。

可等待的队列

joinablequeue

生产者消费者模型

做包子 20 10

包子,比做数据

吃包子 3 5

事件

  • 创建事件对象

    事件对象 = multiprocessing.Event()
    

    理解为,制定了一个行动计划

  • 等待行动指令

    事件对象.wait()
    
  • 开始行动

    事件对象.set()
    
  • 取消行动,继续回归到等待状态(潜伏状态)

    事件对象.clear()
    
  • 判断当前的事件状态

    事件对象.is_set()
    

进程模块中对象的共性

一端发生变化,另一端可以感知到

JoinableQueue

  • 可等待的连接

  • 特点

    • 比普通的进程队列功能增强,多了task_done与join方法
  • 用法

    • 创建

      jq = multiprocessing.JoinableQueue(容量)
      
    • 取数据时

      jq.get()
      jq.task_done()
      

      取出数据后一定要调一下task_done(),否则计数不减的话,join()无法感知

    • 等待连接

      jq.join()
      

      当队列中有数据时会阻塞,当队列中的数据计数为零时,会解阻塞

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值