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

Python使用asyncio包處理并發(fā)的實現(xiàn)代碼

 更新時間:2022年12月06日 14:35:34   作者:程序員老華  
這篇文章主要介紹了Python使用asyncio包處理并發(fā),asyncio包使用事件循環(huán)驅(qū)動的協(xié)程實現(xiàn)并發(fā),本文通過實例代碼給大家介紹的非常詳細(xì)對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

使用 asyncio 包處理并發(fā)

asyncio包:使用事件循環(huán)驅(qū)動的協(xié)程實現(xiàn)并發(fā)。

線程與協(xié)程的對比

'\ thinking' 旋轉(zhuǎn)等待效果

In [1]: import threading
 
In [2]: import itertools
 
In [3]: import time,sys
 
In [4]: class Signal:  # 定義一個簡單的可變對象;go 屬性 從外部控制線程
   ...:     go = True
 
In [5]: def spin(msg,signal):
   ...:     w,flush = sys.stdout.write,sys.stdout.flush
   ...:     for char in itertools.cycle('|/-\\'):  # 從序列中反復(fù)不斷的生成元素
   ...:         status = char + ' ' + msg
   ...:         w(status)
   ...:         flush()
   ...:         w('\x08' * len(status))  # 退格鍵:\x08 文本動畫的訣竅所在
   ...:         time.sleep(1)
   ...:         if not signal.go:
   ...:             break
   ...:     w(' ' * len(status) + '\x08' * len(status))
 
In [6]: def slow():
   ...:     time.sleep(3)
   ...:     return 42
 
In [9]: def super():
   ...:     signal = Signal()
   ...:     sp = threading.Thread(target=spin,args=('thinking',signal))
   ...:     print('============')
   ...:     sp.start()
   ...:     res = slow()
   ...:     signal.go = False
   ...:     sp.join()
   ...:     return res

注意:Python 沒有提供終止線程的 API ,這是有意為之的。若想關(guān)閉線程,必須給線程發(fā)送消息。這里用的是 signal.go 屬性。干凈的規(guī)則的退出。

適合 asyncio API 的協(xié)程:

1 定義體必須使用 yield from ,而不能使用 yield

2 協(xié)程要由調(diào)用方驅(qū)動,并由調(diào)用方通過 yield from 調(diào)用

3 或者把協(xié)程傳給 asyncio 包中的某個函數(shù),比如 asyncio.async()

4 @asyncio.coroutine 裝飾器應(yīng)該用在協(xié)程上

asyncio 實現(xiàn) 動畫效果

In [1]: import asyncio
 
In [3]: import itertools
 
In [4]: import sys
 
# 交給 asyncio 處理的協(xié)程需要使用該裝飾器裝飾。這不是強制要求,但是強烈建議這么做。
In [5]: @asyncio.coroutine
   ...: def spin(msg):  # 不需要多線程的關(guān)閉參數(shù)
   ...:     w,flush = sys.stdout.write, sys.stdout.flush
   ...:     for char in itertools.cycle('|/-\\'):
   ...:         status = char + ' ' + msg
   ...:         w(status)
   ...:         flush()
   ...:         w('\x08' * len(status))
   ...:         try:
   ...:             yield from asyncio.sleep(.1)  # 不會阻塞事件循環(huán)
                # spin 函數(shù)蘇醒后,取消請求 異常,退出循環(huán)
   ...:         except asyncio.CancelledError:
   ...:             break
   ...:     write(' ' * len(status) + '\x08' * len(status))
   ...:
 
In [6]: @asyncio.coroutine
   ...: def slow():
            # 把控制權(quán)交給主循環(huán),休眠結(jié)束后,結(jié)束這個協(xié)程
   ...:     yield from asyncio.sleep(3)
   ...:     return 42
   ...:
 
In [9]: @asyncio.coroutine
   ...: def sup():
            # asyncio 排定spin協(xié)程的運行時間,封裝成一個 Task對象 sp
   ...:     sp = asyncio.async(spin('thinking!'))
   ...:     print('spin obj:',sp)
            # sup 也是協(xié)程,因此,可以使用 yield from 驅(qū)動 slow()
   ...:     res = yield from slow()
            sp.cancel()
   ...:     return res
   ...:
 
In [10]: def main():
    ...:     loop = asyncio.get_event_loop()
    ...:     res = loop.run_until_complete(sup())
    ...:     loop.close()
    ...:     print('answer:',res)
    ...:
 
In [11]: main()
D:\python36\Scripts\ipython:3: DeprecationWarning: asyncio.async() function is deprecated, use ensure_future()
spin obj: <Task pending coro=<spin() running at <ipython-input-5-0304845f34e1>:1>>
answer: 42!

除非想阻塞主線程,從而凍結(jié)事件循環(huán)或整個應(yīng)用,否則不要在 asyncio 協(xié)程中使用 time.sleep() 。如果協(xié)程需要一段時間內(nèi)什么也不做,應(yīng)該使用 yield from asyncio.sleep() 。

@asyncio.coroutine 裝飾器不是強制要求,但是強烈建議這么做,因為這樣能

1 把協(xié)程凸顯出來,有助于調(diào)試。

2 如果還未產(chǎn)出值,協(xié)程就被垃圾回收了(意味著有操作未完成,因此有可能是個缺陷),那就可以發(fā)出警告了。

3 這個裝飾器不會預(yù)激協(xié)程。

到此這篇關(guān)于Python使用asyncio包處理并發(fā)的實現(xiàn)代碼的文章就介紹到這了,更多相關(guān)Python asyncio包內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python字典改變value值方法總結(jié)

    python字典改變value值方法總結(jié)

    在本文里小編給大家分享了關(guān)于python字典如何改變value值的相關(guān)知識點以及實例代碼,需要的朋友們學(xué)習(xí)下。
    2019-06-06
  • 基于python制作簡易版學(xué)生信息管理系統(tǒng)

    基于python制作簡易版學(xué)生信息管理系統(tǒng)

    這篇文章主要介紹了基于python制作簡易版學(xué)生信息管理系統(tǒng),文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)python的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-04-04
  • 詳解Django中的權(quán)限和組以及消息

    詳解Django中的權(quán)限和組以及消息

    這篇文章主要介紹了詳解Django中的權(quán)限和組以及消息,在Python百花齊放的web框架中,Django是人氣最高的一個,需要的朋友可以參考下
    2015-07-07
  • Python?變量類型實例詳解

    Python?變量類型實例詳解

    這篇文章主要介紹了Python?變量類型實例詳解,基于變量的數(shù)據(jù)類型,解釋器會分配指定內(nèi)存,并決定什么數(shù)據(jù)可以被存儲在內(nèi)存中,接下來更多詳細(xì)內(nèi)容需要的小伙伴可以參考下面文章,希望對你有所幫助
    2022-02-02
  • 使用Python實現(xiàn)將多表分批次從數(shù)據(jù)庫導(dǎo)出到Excel

    使用Python實現(xiàn)將多表分批次從數(shù)據(jù)庫導(dǎo)出到Excel

    這篇文章主要介紹了使用Python實現(xiàn)將多表分批次從數(shù)據(jù)庫導(dǎo)出到Excel,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • 詳解Python如何在終端打印字體顏色

    詳解Python如何在終端打印字體顏色

    日常開發(fā)中,海量的信息堆砌在控制臺中,就會導(dǎo)致各種信息都顯示在一起,降低了重要信息的可讀性。這時候,如果能給重要的信息加上差異的字體顏色,那么就會更加顯眼。本文將介紹Python實現(xiàn)終端打印字體顏色的方法,需要的可以了解一下
    2022-10-10
  • python獲取當(dāng)前計算機cpu數(shù)量的方法

    python獲取當(dāng)前計算機cpu數(shù)量的方法

    這篇文章主要介紹了python獲取當(dāng)前計算機cpu數(shù)量的方法,涉及Python操作計算機硬件的技巧,代碼簡單易懂,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • Python-Tkinter Text輸入內(nèi)容在界面顯示的實例

    Python-Tkinter Text輸入內(nèi)容在界面顯示的實例

    今天小編就為大家分享一篇Python-Tkinter Text輸入內(nèi)容在界面顯示的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python面向?qū)ο缶幊蘲epr方法示例詳解

    Python面向?qū)ο缶幊蘲epr方法示例詳解

    這篇文章主要介紹了Python面向?qū)ο缶幊蘲epr方法的示例詳解,文中附含詳細(xì)的代碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • Python判斷List中是否包含某個元素

    Python判斷List中是否包含某個元素

    在Python中,判斷一個列表(List)是否包含某個特定元素是常見的任務(wù)之一,本文就來介紹一下多種判斷List成員包含性的方法,并提供豐富的示例代碼,以幫助大家更好地理解和運用這些技術(shù)
    2023-12-12

最新評論