0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

通過例子由淺入深的理解yield協(xié)程

冬至配餃子 ? 來源:繆斯之子 ? 作者:肖新苗 ? 2022-08-23 11:12 ? 次閱讀

題記

本系列目標(biāo)是通過例子由淺入深的理解協(xié)程.

讀者

需要有一定的python基礎(chǔ), 概念部分建議閱讀經(jīng)典書: 流暢的python 或者 查看w3c school 或者 菜鳥教程

基本概念

生成器:只要 Python 函數(shù)的定義體中有 yield 關(guān)鍵字,該函數(shù)就是生成器函數(shù),調(diào)用生成器函數(shù)返回的是生成器對象

yield關(guān)鍵字:總的來說就是:產(chǎn)出和讓步,產(chǎn)出結(jié)果,讓出控制權(quán)

send:send() 方法致使協(xié)程前進(jìn)到下一個yield 語句,另外,生成器可以作為協(xié)程使用

例子說明

yield的執(zhí)行流程, 并制作了一個生成器調(diào)用的共同方法print_value

def yield1():
'''
整體解釋:1將作為第一個send方法的返回值,b是第二個send方法的參數(shù),
最后的return是作為最后一個send方法的返回值
'''
# 4.yield1()協(xié)程:阻塞在此,執(zhí)行yield產(chǎn)出結(jié)果為1,把控制權(quán)給主線程
# 9.yield1()協(xié)程:阻塞解除,獲得輸入值2,并賦值給b
b = yield 1
# 10.yield1()協(xié)程:返回b
return b


def yield2():
'''
協(xié)程阻塞在此,執(zhí)行yield產(chǎn)出結(jié)果為None,并交出控制權(quán)給主線程
注: 因為yield后面沒有值,所以是None
'''
yield
# 如果沒有返回值,會return None
pass


def yield3():
yield 1


def print_value(f, args):

try:
# 3.print_value方法:對yield1()協(xié)程執(zhí)行send
# 5.print_value方法:接收yield1()協(xié)程的返回值1,并賦值給b
# 8.print_value方法:對yield1()協(xié)程再次執(zhí)行send,并傳入2
b = f.send(args)
except StopIteration as e:
'''
11.print_value方法:接收yield1()協(xié)程的返回值,
如果是最后一個迭代,就會進(jìn)入到這個異常捕獲
'''

print(f'{f.__name__}返回值 {e.value}')
return e.value
else:
# 6.print_value方法:打印b
print(f'{f.__name__}接收 ')

'''

1.主線程:`yield1`是生成器函數(shù),`yield1()`調(diào)用生成器函數(shù),

返回生成器對象也可以稱作協(xié)程
'''
ys = [yield1(), yield2(), yield3()]
for y in ys:
# 2.主線程:y是yield1()生成器對象,第一次發(fā)送None
# 12.主線程:y是yield2()生成器對象,第一次發(fā)送None.
# 注:yield2 yield3根yield1差不多所以12步以后的都略過了
print_value(y, None)
# 7.主線程:第二次send參數(shù)為2
print_value(y, 2)


結(jié)果:
yield1接收 1
yield1返回值 2
yield2接收 None
yield2返回值 None
yield3接收 1
yield3返回值 None


審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 生成器
    +關(guān)注

    關(guān)注

    7

    文章

    313

    瀏覽量

    20951
  • python
    +關(guān)注

    關(guān)注

    55

    文章

    4768

    瀏覽量

    84376
收藏 人收藏

    評論

    相關(guān)推薦

    使用TMS320C6416協(xié)處理器:Turbo協(xié)處理器(TCP)

    電子發(fā)燒友網(wǎng)站提供《使用TMS320C6416協(xié)處理器:Turbo協(xié)處理器(TCP).pdf》資料免費下載
    發(fā)表于 10-23 10:16 ?0次下載
    使用TMS320C6416<b class='flag-5'>協(xié)</b>處理器:Turbo<b class='flag-5'>協(xié)</b>處理器(TCP)

    使用TMS320C6416協(xié)處理器:Viterbi協(xié)處理器(VCP)

    電子發(fā)燒友網(wǎng)站提供《使用TMS320C6416協(xié)處理器:Viterbi協(xié)處理器(VCP).pdf》資料免費下載
    發(fā)表于 10-21 09:36 ?0次下載
    使用TMS320C6416<b class='flag-5'>協(xié)</b>處理器:Viterbi<b class='flag-5'>協(xié)</b>處理器(VCP)

    安達(dá)發(fā)|APS高級排高級物料需求計劃

    APS高級排高級物料需求計劃是在制造業(yè)中非常重要的概念。它們分別涉及到生產(chǎn)計劃和物料管理,對于提高生產(chǎn)效率、降低成本和滿足客戶需求具有重要意義。下面我將詳細(xì)介紹這兩個概念及其在實際生產(chǎn)
    的頭像 發(fā)表于 09-25 17:49 ?222次閱讀
    安達(dá)發(fā)|APS高級排<b class='flag-5'>程</b>高級物料需求計劃

    基于APS排系統(tǒng)的PDM功能

    APS系統(tǒng)(AdvancedPlanningandScheduling,先進(jìn)計劃與排)是一種基于APS系統(tǒng)(AdvancedPlanningandScheduling,先進(jìn)計劃與排)是一種
    的頭像 發(fā)表于 09-21 16:53 ?178次閱讀
    基于APS排<b class='flag-5'>程</b>系統(tǒng)的PDM功能

    國內(nèi)APS高級排軟件的全面解析

    在現(xiàn)代制造業(yè)和物流行業(yè)中,高效的生產(chǎn)計劃和庫存管理是企業(yè)提升競爭力的關(guān)鍵。隨著信息技術(shù)的發(fā)展,高級排軟件(AdvancedPlanningandScheduling,APS)成為了企業(yè)優(yōu)化資源配置
    的頭像 發(fā)表于 09-21 16:49 ?277次閱讀
    國內(nèi)APS高級排<b class='flag-5'>程</b>軟件的全面解析

    晶泰科技與協(xié)鑫集團(tuán)簽署戰(zhàn)略合作協(xié)議

    近日,在蘇州協(xié)鑫能源中心,晶泰科技與協(xié)鑫集團(tuán)共同見證了雙方戰(zhàn)略合作新篇章的開啟,正式簽署了為期五年的戰(zhàn)略合作協(xié)議。此次合作,不僅標(biāo)志著兩大行業(yè)巨頭的強(qiáng)強(qiáng)聯(lián)合,更預(yù)示著新能源材料研發(fā)領(lǐng)域?qū)⒂瓉硪粓鲇扇斯ぶ悄芘c自動化技術(shù)引領(lǐng)的深刻變革。
    的頭像 發(fā)表于 09-03 14:34 ?422次閱讀

    請問ESP32s3 ULP RISC-V協(xié)處理器是否支持ADC的讀?。?/a>

    我在ULP RISC-V協(xié)處理器的例程中,沒有發(fā)現(xiàn)有對ADC的操作,請問RISC-V協(xié)處理器目前還不支持嗎?使用的IDF版本為4.4.2。 我想在ULP模式下,通過ADC來讀取外部器件的數(shù)據(jù)。
    發(fā)表于 06-14 07:38

    使用C語言實現(xiàn)的CRC計算單元的例子

    使用C語言實現(xiàn)的CRC計算單元的例子
    的頭像 發(fā)表于 05-16 16:16 ?815次閱讀

    鴻蒙輕內(nèi)核源碼分析:MMU 協(xié)處理器

    1、 ARM C15 協(xié)處理器 在 ARM 嵌入式應(yīng)用系統(tǒng)中, 很多系統(tǒng)控制由 ARM CP15 協(xié)處理器來完成的。CP15 協(xié)處理器包含編號 0-15 的 16 個 32 位的寄存器。例如,ARM
    的頭像 發(fā)表于 02-20 14:28 ?502次閱讀
    鴻蒙輕內(nèi)核源碼分析:MMU <b class='flag-5'>協(xié)</b>處理器

    談?wù)?b class='flag-5'>協(xié)的那些事兒

    隨著異步編程的發(fā)展以及各種并發(fā)框架的普及,協(xié)作為一種異步編程規(guī)范在各類語言中地位逐步提高。我們不單單會在自己的程序中使用協(xié),各類框架如fastapi,aiohttp等也都是基于異步
    的頭像 發(fā)表于 01-26 11:36 ?1076次閱讀
    談?wù)?b class='flag-5'>協(xié)</b><b class='flag-5'>程</b>的那些事兒

    如何通過仿真動圖理解各種傳感器的原理呢?

    如何通過仿真動圖理解各種傳感器的原理呢?
    發(fā)表于 01-15 10:39 ?468次閱讀
    如何<b class='flag-5'>通過</b>仿真動圖<b class='flag-5'>理解</b>各種傳感器的原理呢?

    BlueNRG系列協(xié)處理器實戰(zhàn)經(jīng)驗簡介

    BlueNRG 系列芯片從最早的一代 BlueNRG-MS 開始就支持協(xié)處理器模式。
    的頭像 發(fā)表于 01-05 18:16 ?1721次閱讀
    BlueNRG系列<b class='flag-5'>協(xié)</b>處理器實戰(zhàn)經(jīng)驗簡介

    for循環(huán)的基本例子

    for循環(huán)是一種常見的循環(huán)結(jié)構(gòu),用于重復(fù)執(zhí)行一段代碼。它通常由三個部分組成:循環(huán)變量的初始化、循環(huán)條件和循環(huán)變量更新。下面將通過詳細(xì)的例子來解釋for循環(huán)的用法和工作原理。 首先,我們來考慮一個簡單
    的頭像 發(fā)表于 11-22 10:00 ?2018次閱讀

    python最簡單for循環(huán)例子

    Python是一種簡單而又強(qiáng)大的編程語言,通過其清晰的語法和豐富的功能庫,我們可以實現(xiàn)各種各樣的任務(wù)。其中一個最基本的語法結(jié)構(gòu)就是for循環(huán),讓我們來看一下如何使用for循環(huán)來編寫一個最簡單的例子
    的頭像 發(fā)表于 11-21 14:53 ?910次閱讀

    何選擇一個合適的協(xié)來獲得CPU執(zhí)行權(quán)

    如今雖不敢說協(xié)已經(jīng)是紅的發(fā)紫,但確實是越來越受到了大家的重視。Golang中的已經(jīng)是只有g(shù)oroutine,以至于很多go程序員是只知有協(xié),不知有線程了。就連C++也在最新的C++
    的頭像 發(fā)表于 11-13 14:10 ?365次閱讀
    何選擇一個合適的<b class='flag-5'>協(xié)</b><b class='flag-5'>程</b>來獲得CPU執(zhí)行權(quán)