欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python  Asyncio模塊實(shí)現(xiàn)的生產(chǎn)消費(fèi)者模型的方法

 更新時(shí)間:2021年03月01日 11:02:59   投稿:mrr  
這篇文章主要介紹了Python Asyncio模塊實(shí)現(xiàn)的生產(chǎn)消費(fèi)者模型的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

asyncio的關(guān)鍵字說明

  • event_loop事件循環(huán):程序開啟一個(gè)無限循環(huán),把一些函數(shù)注冊(cè)到事件循環(huán)上,當(dāng)滿足事件發(fā)生的時(shí)候,調(diào)用相應(yīng)的協(xié)程函數(shù)
  • coroutine協(xié)程:協(xié)程對(duì)象,指一個(gè)使用async關(guān)鍵字定義的函數(shù),它的調(diào)用不會(huì)立即執(zhí)行函數(shù),而是會(huì)返回一個(gè)協(xié)程對(duì)象,協(xié)程對(duì)象需要注冊(cè)到事件循環(huán),由事件循環(huán)調(diào)用。
  • task任務(wù):一個(gè)協(xié)程對(duì)象就是一個(gè)原生可以掛起的函數(shù),任務(wù)則是對(duì)協(xié)程進(jìn)一步封裝,其中包含了任務(wù)的各種狀態(tài)
  • future:代表將來執(zhí)行或沒有執(zhí)行的任務(wù)結(jié)果。它和task上沒有本質(zhì)上的區(qū)別
  • async/await關(guān)鍵字:async定義一個(gè)協(xié)程,await用于掛起阻塞的異步調(diào)用接口,在python3.4是使用asyncio.coroutine/yield from

在設(shè)計(jì)模式中,生產(chǎn)消費(fèi)者模型占有非常重要的地位,這個(gè)模型在現(xiàn)實(shí)世界中也有很多有意思的對(duì)應(yīng)場(chǎng)景,比如做包子的人和吃包子的人,當(dāng)兩者速度不匹配時(shí),就需要有一個(gè)模型來做匹配(偶合),實(shí)現(xiàn)做的包子都會(huì)依次消費(fèi)掉。

import asyncio

class ConsumerProducerModel:
  def __init__(self, producer, consumer, queue=asyncio.Queue(), plate_size=6): # the plate holds 6pcs bread
    self.queue = queue
    self.producer = producer
    self.consumer = consumer
    self.plate_size = plate_size

  async def produce_bread(self):
    for i in range(self.plate_size):
      bread = f"bread {i}"
      await asyncio.sleep(0.5) # bread makes faster, 0.5s/pc
      await self.queue.put(bread)
      print(f'{self.producer} makes {bread}')

  async def consume_bread(self):
    while True:
      bread = await self.queue.get()
      await asyncio.sleep(1) # eat slower, 1s/pc
      print(f'{self.consumer} eats {bread}')
      self.queue.task_done()

async def main():
  queue = asyncio.Queue()
  cp1 = ConsumerProducerModel("John", "Grace", queue) # group 1
  cp2 = ConsumerProducerModel("Mike", "Lucy", queue) # group 2

  producer_1 = cp1.produce_bread()
  producer_2 = cp2.produce_bread()

  consumer_1 = asyncio.ensure_future(cp1.consume_bread())
  consumer_2 = asyncio.ensure_future(cp2.consume_bread())

  await asyncio.gather(*[producer_1, producer_2])
  await queue.join()
  consumer_1.cancel()
  consumer_2.cancel()

if __name__ == '__main__':
  loop = asyncio.get_event_loop()
  loop.run_until_complete(main())
  loop.close()

生產(chǎn)消費(fèi)者模型可以使用多線程和隊(duì)列來實(shí)現(xiàn),這里選擇協(xié)程不僅是因?yàn)樾阅懿诲e(cuò),而且整個(gè)下來邏輯清晰:

1. 先定義初始化的東西,要有個(gè)隊(duì)列,要有生產(chǎn)者,要有消費(fèi)者,要有裝面包的盤子大??;

2. 生產(chǎn)者:根據(jù)盤子大小生產(chǎn)出對(duì)應(yīng)的東西(面包),將東西放入盤子(queue);

3. 消費(fèi)者:從盤子上取東西,每次取東西都是一個(gè)任務(wù),每次任務(wù)完成,就標(biāo)記為task_done(調(diào)用函數(shù))。在這個(gè)層面,一直循環(huán);

4. 主邏輯:實(shí)例化生產(chǎn)消費(fèi)者模型對(duì)象,創(chuàng)建生產(chǎn)者協(xié)程,創(chuàng)建任務(wù)(ensure_future),收集協(xié)程結(jié)果,等待所有線程結(jié)束(join),手動(dòng)取消兩個(gè)消費(fèi)者協(xié)程;

5. 運(yùn)行:首先創(chuàng)建事件循環(huán),然后進(jìn)入主邏輯,直到完成,關(guān)閉循環(huán)。

到此這篇關(guān)于Python Asyncio模塊實(shí)現(xiàn)的生產(chǎn)消費(fèi)者模型的方法的文章就介紹到這了,更多相關(guān)Python生產(chǎn)消費(fèi)者模型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于opencv實(shí)現(xiàn)手勢(shì)控制音量(案例詳解)

    基于opencv實(shí)現(xiàn)手勢(shì)控制音量(案例詳解)

    這篇文章主要介紹了基于opencv的手勢(shì)控制音量和ai換臉,通過定義了一個(gè)名為 handDetector 的類,用于檢測(cè)和跟蹤手部,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • Django之importlib模塊的具體使用

    Django之importlib模塊的具體使用

    本文主要介紹了Django之importlib模塊的具體使用,importlib模塊是Python中用于動(dòng)態(tài)加載和導(dǎo)入模塊的內(nèi)置模塊,有需要了解jquery event事件用法的朋友可參考
    2023-11-11
  • python中apply函數(shù)詳情

    python中apply函數(shù)詳情

    這篇文章主要介紹了python中apply函數(shù)詳情,該函數(shù)最有用的是第一個(gè)參數(shù),這個(gè)參數(shù)是函數(shù),相當(dāng)于C/C++的函數(shù)指針,更多詳細(xì)內(nèi)容,需要的小伙伴可以參考下面文章內(nèi)容
    2022-01-01
  • python cv2在驗(yàn)證碼識(shí)別中應(yīng)用實(shí)例解析

    python cv2在驗(yàn)證碼識(shí)別中應(yīng)用實(shí)例解析

    這篇文章主要介紹了python cv2在驗(yàn)證碼識(shí)別中應(yīng)用實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • Python opencv醫(yī)學(xué)處理的實(shí)現(xiàn)過程

    Python opencv醫(yī)學(xué)處理的實(shí)現(xiàn)過程

    這篇文章主要介紹了Python opencv醫(yī)學(xué)處理的實(shí)現(xiàn)過程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • freeswitch開源通信 python模塊介紹

    freeswitch開源通信 python模塊介紹

    freeswitch支持多種語言的業(yè)務(wù)開發(fā),包括C/C++,java,python,js,lua,Golang等等。freeswitch在使用python做業(yè)務(wù)開發(fā)時(shí),有倆種接入方式,一種是ESL接口,另一種是mod_python模塊。本文主要介紹的是fs內(nèi)部的mod_python語言支持模塊,需要的朋友可以參考下面文章內(nèi)容
    2021-09-09
  • pyx文件 生成pyd 文件用于 cython調(diào)用的實(shí)現(xiàn)

    pyx文件 生成pyd 文件用于 cython調(diào)用的實(shí)現(xiàn)

    這篇文章主要介紹了pyx文件 生成pyd 文件用于 cython調(diào)用的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Python基于smtplib協(xié)議實(shí)現(xiàn)發(fā)送郵件

    Python基于smtplib協(xié)議實(shí)現(xiàn)發(fā)送郵件

    這篇文章主要介紹了Python基于smtplib協(xié)議實(shí)現(xiàn)發(fā)送郵件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Python爬蟲實(shí)戰(zhàn)JS逆向AES逆向加密爬取

    Python爬蟲實(shí)戰(zhàn)JS逆向AES逆向加密爬取

    一個(gè)建筑行業(yè)的堂哥為了搞一些商業(yè)數(shù)據(jù)前前后后花了1w,辣條我半個(gè)小時(shí)就能解決的事情,這就是技術(shù)的魅力!聲明:爬取是的公開數(shù)據(jù)
    2021-10-10
  • 通過實(shí)例淺析Python對(duì)比C語言的編程思想差異

    通過實(shí)例淺析Python對(duì)比C語言的編程思想差異

    這篇文章主要介紹了通過實(shí)例淺析Python對(duì)比C語言的編程思想差異,作為面向?qū)ο蠛兔嫦蜻^程的編程語言代表,二者的對(duì)比可謂經(jīng)典,需要的朋友可以參考下
    2015-08-08

最新評(píng)論