do --create coroutine table --coroutine state: suspended, running, dead, normal --when create the coroutine, the status is suspended, After calling it, the status is dead --get the coroutine status by the way coroutine.status local coA = 0; local coB = 0; function createCoroutineA() coA = coroutine.create( function() --for i = 0, 10 do print("coA: ", 0); print("coB status: ", coroutine.status(coB)); --normal status print("coA status: ", coroutine.status(coA)); print("coA coroutine next status"); --coroutine.yield();--the current coroutine is suspended --end end ); print("From coA to resume coB"); end function createCoroutineB() coB = coroutine.create( function() --for i = 0, 10 do print("coB: ", 0); print("coA status: ", coroutine.status(coA)); coroutine.resume(coA); --when resume coA, the coB will suspended, calling coB ,the coA status is --suspended and dead, this time will continue to execute the next code print("coB status: ", coroutine.status(coB)); print("coB coroutine next status"); --coroutine.yield(); --end end ); print("From coB to resume coA"); end --display the coA and coB status createCoroutineA(); print(coroutine.status(coA)); createCoroutineB(); print(coroutine.status(coB)); coroutine.resume(coB); print(coroutine.resume(coB)); --if the coroutine is dead ,the resume will resume false, and can't resume the dead coroutine --print("coA status: ", coroutine.status(coA)); --print("coB status: ", coroutine.status(coB)); end
注:
resume得到返回值,
如果有对应的yield在wait resume,那么yield的参数作为resum的返回值,第一个返回值表示coroutine没有错误,后面的返回值个数及其值视yeild参数而定。
如果没有yield在wait,那么返回值是对应函数的返回值,:true,* * *
do --create coroutine table --coroutine state: suspended, running, dead, normal --when create the coroutine, the status is suspended, After calling it, the status is dead --get the coroutine status by the way coroutine.status local coA = 0; local coB = 0; function createCoroutineA() coA = coroutine.create( function(paramA, paramB) --for i = 0, 10 do print("coA: ", 0); coroutine.yield(paramA, paramB);--the current coroutine is suspended --end return 100, 200; end ); print("From coA to resume coB"); end function createCoroutineB() coB = coroutine.create( function() --for i = 0, 10 do print("coB: ", 0); print("coA status: ", coroutine.status(coA)); coroutine.resume(coA); --when resume coA, the coB will suspended, calling coB ,the coA status is --suspended and dead, this time will continue to execute the next code print("coB status: ", coroutine.status(coB)); print("coB coroutine next status"); --coroutine.yield(); --end end ); print("From coB to resume coA"); end createCoroutineA(); --if not yield is waiting ,the return values that the main function return as the results of the resume --or the return as the yield params print( coroutine.resume(coA, 10, 20));--OutPut:true, 10, 20 end
主要内容:什么是协同(coroutine)?,coroutine_test.lua 文件,实例,生产者-消费者问题,实例什么是协同(coroutine)? Lua 协同程序(coroutine)与线程比较类似:拥有独立的堆栈,独立的局部变量,独立的指令指针,同时又与其它协同程序共享全局变量和其它大部分东西。 协同是非常强大的功能,但是用起来也很复杂。 线程和协同程序区别 线程与协同程序的主要区别在于,一个具有多个线程的程序可以同时运行几个线程,而协同程序却需要彼此协作的运行。 在任一指定时刻只有
什么是协同(coroutine)? Lua 协同程序(coroutine)与线程比较类似:拥有独立的堆栈,独立的局部变量,独立的指令指针,同时又与其它协同程序共享全局变量和其它大部分东西。 协同是非常强大的功能,但是用起来也很复杂。 线程和协同程序区别 线程与协同程序的主要区别在于,一个具有多个线程的程序可以同时运行几个线程,而协同程序却需要彼此协作的运行。 在任一指定时刻只有一个协同程序在运行,
协程(coroutine)并不是 Lua 独有的概念,如果让我用一句话概括,那么大概就是:一种能够在运行途中主动中断,并且能够从中断处恢复运行的特殊函数。(嗯,其实不是函数。) 举个最原始的例子: 下面给出一个最简单的 Lua 中 coroutine 的用法演示: function greet() print "hello world" end co = coroutine.cr
本文向大家介绍Lua中的协同程序探究,包括了Lua中的协同程序探究的使用技巧和注意事项,需要的朋友参考一下 哎,周五晚上我都还这么努力看书,真是好孩子。(小若:不想吐槽了) 其实我都准备玩游戏看电影去的了,但是这书就摆在桌子上,而且正对着我,就想着,扫两眼吧。 结果一扫就不对劲了,因为这内容有点绕,有点小混乱,如果我现在不记录下来的话,下周一可能又要重新看一次了。 好吧,今天我们来聊聊协同程序
本文向大家介绍举例详解Lua中的协同程序编程,包括了举例详解Lua中的协同程序编程的使用技巧和注意事项,需要的朋友参考一下 协同程序是协同的性质,可以把两个或更多的方法以可控制的方式执行。随着协同程序,在任何给定的时间,只有其协同程序运行之一,这在运行协同程序只能暂停其执行时,明确要求暂停。 上述定义可能看起来模糊。来告诉它更清楚,假设我们有两个方法,一个主程序方法和协同程序。当我们使用恢复功能
本文向大家介绍Lua编程示例(七):协同程序基础逻辑,包括了Lua编程示例(七):协同程序基础逻辑的使用技巧和注意事项,需要的朋友参考一下 输出结果: