舉例詳解Lua中的協(xié)同程序編程
協(xié)同程序是協(xié)同的性質(zhì),可以把兩個(gè)或更多的方法以可控制的方式執(zhí)行。隨著協(xié)同程序,在任何給定的時(shí)間,只有其協(xié)同程序運(yùn)行之一,這在運(yùn)行協(xié)同程序只能暫停其執(zhí)行時(shí),明確要求暫停。
上述定義可能看起來(lái)模糊。來(lái)告訴它更清楚,假設(shè)我們有兩個(gè)方法,一個(gè)主程序方法和協(xié)同程序。當(dāng)我們使用恢復(fù)功能調(diào)用協(xié)程,其開(kāi)始執(zhí)行,當(dāng)我們調(diào)用yield功能,暫停執(zhí)行。再次同協(xié)程可以繼續(xù)從它被暫停的另一個(gè)恢復(fù)功能調(diào)用執(zhí)行。這個(gè)過(guò)程可以繼續(xù),直到執(zhí)行了協(xié)程的結(jié)束。
協(xié)同程序可用的功能
下表列出了在Lua協(xié)同程序及其相應(yīng)的使用所有的可用功能。
例子
讓我們看一個(gè)例子就明白了協(xié)程的概念。
local tempvar3 =10
print("coroutine section 1", value1, value2, tempvar3)
local tempvar1 = coroutine.yield(value1+1,value2+1)
tempvar3 = tempvar3 + value1
print("coroutine section 2",tempvar1 ,tempvar2, tempvar3)
local tempvar1, tempvar2= coroutine.yield(value1+value2, value1-value2)
tempvar3 = tempvar3 + value1
print("coroutine section 3",tempvar1,tempvar2, tempvar3)
return value2, "end"
end)
print("main", coroutine.resume(co, 3, 2))
print("main", coroutine.resume(co, 12,14))
print("main", coroutine.resume(co, 5, 6))
print("main", coroutine.resume(co, 10, 20))
當(dāng)我們運(yùn)行上面的程序,會(huì)得到下面的輸出。
main true 4 3
coroutine section 2 12 nil 13
main true 5 1
coroutine section 3 5 6 16
main true 2 end
main false cannot resume dead coroutine
上面的例子是做什么?
如之前所提到的,我們使用恢復(fù)功能的動(dòng)作開(kāi)始,并產(chǎn)生函數(shù)來(lái)停止操作。此外,可以看到有由協(xié)程恢復(fù)功能接收多個(gè)返回值。這里將解釋上面的程序每一個(gè)步驟,使之清楚。
- 首先,我們創(chuàng)建了一個(gè)協(xié)同程序,并把它分配給變量名合作和協(xié)同程序需要在兩個(gè)變量作為參數(shù)。
- 當(dāng)我們稱之為第一恢復(fù)功能,值3和2分別被保持在臨時(shí)變量value1和value2,直到協(xié)程的結(jié)束。
- 為了理解這一點(diǎn),我們已經(jīng)使用了tempvar3初始化為10,它被由協(xié)程的后續(xù)調(diào)用更新為13和16,因?yàn)橹?被保留為3,整個(gè)協(xié)同程序的執(zhí)行。
- 第一個(gè)coroutine.yield返回兩個(gè)值4和3 是由更新輸入?yún)?shù)3和2,yield語(yǔ)句得到了恢復(fù)函數(shù)。它還接收協(xié)程執(zhí)行的真/假狀態(tài)。
- 關(guān)于協(xié)程的另一件事是如何恢復(fù)調(diào)用下一參數(shù)寫(xiě)成的照顧,在上述的例子; 可以看到,coroutine.yield分配變量接收到下一次調(diào)用參數(shù),它提供做新業(yè)務(wù)與現(xiàn)有參數(shù)值之間的關(guān)系的一種強(qiáng)有力的方式。
- 最后,一旦在協(xié)同程序的所有語(yǔ)句執(zhí)行時(shí),后續(xù)調(diào)用將返回false,并且“不能恢復(fù)死協(xié)同程序”語(yǔ)句作為回應(yīng)。
另一個(gè)協(xié)程的例子
讓我們來(lái)看一個(gè)簡(jiǎn)單的協(xié)同程序返回一個(gè)數(shù)字,從1到5 yield函數(shù)恢復(fù)功能。它創(chuàng)建協(xié)同程序,如果沒(méi)有則恢復(fù)現(xiàn)有的協(xié)程。
local function getNumberHelper()
co = coroutine.create(function ()
coroutine.yield(1)
coroutine.yield(2)
coroutine.yield(3)
coroutine.yield(4)
coroutine.yield(5)
end)
return co
end
if(numberHelper) then
status, number = coroutine.resume(numberHelper);
if coroutine.status(numberHelper) == "dead" then
numberHelper = getNumberHelper()
status, number = coroutine.resume(numberHelper);
end
return number
else
numberHelper = getNumberHelper()
status, number = coroutine.resume(numberHelper);
return number
end
end
for index = 1, 10 do
print(index, getNumber())
end
當(dāng)我們運(yùn)行上面的程序,會(huì)得到下面的輸出。
2 2
3 3
4 4
5 5
6 1
7 2
8 3
9 4
10 5
往往有協(xié)同程序與多道程序語(yǔ)言的線程的比較,但要明白,協(xié)同程序線程有類似的功能,但只有一次執(zhí)行,并不會(huì)執(zhí)行兼任。
我們控制程序的執(zhí)行順序,以滿足與提供暫時(shí)保留某些信息的需求。使用全局變量與協(xié)程,提供了協(xié)同程序更加靈活。
- Lua協(xié)程(coroutine)程序運(yùn)行分析
- Lua的協(xié)程(coroutine)簡(jiǎn)介
- Lua之協(xié)同程序coroutine代碼實(shí)例
- Lua協(xié)同程序(COROUTINE)運(yùn)行步驟分解
- Lua協(xié)同程序函數(shù)coroutine使用實(shí)例
- Lua編程示例(七):協(xié)同程序基礎(chǔ)邏輯
- Lua中的協(xié)同程序詳解
- Lua中的協(xié)同程序之resume-yield間的數(shù)據(jù)返回研究
- Lua中的協(xié)同程序探究
- Lua協(xié)同程序coroutine的簡(jiǎn)介及優(yōu)缺點(diǎn)
相關(guān)文章
lua讀取redis數(shù)據(jù)的null判斷示例代碼
最近在工作中遇到了一個(gè)問(wèn)題,通過(guò)查找相關(guān)資料才得知原因是因?yàn)榉祷亟Y(jié)果的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于lua讀取redis數(shù)據(jù)的null判斷的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-09-09Lua基礎(chǔ)教程之表(Table)學(xué)習(xí)筆記
這篇文章主要介紹了Lua基礎(chǔ)教程之表(Table)學(xué)習(xí)筆記,本文來(lái)自個(gè)人總結(jié),需要的朋友可以參考下2014-09-09lua開(kāi)發(fā)中實(shí)現(xiàn)MVC框架的簡(jiǎn)單應(yīng)用
最近的游戲項(xiàng)目中使用了lua腳本來(lái)開(kāi)發(fā),項(xiàng)目中用到了MVC框架,最近有朋友問(wèn)我怎么弄,在這里簡(jiǎn)單分享一下思路和一些開(kāi)發(fā)中的技巧。有需要的小伙伴可以參考下。2015-04-04Lua中的元表(metatable)、元方法(metamethod)詳解
這篇文章主要介紹了Lua中的元表(metatable)、元方法(metamethod)詳解,本文對(duì)它做了詳細(xì)講解,并給出實(shí)例來(lái)說(shuō)明,需要的朋友可以參考下2014-09-09