脚本专栏 发布日期:2025/1/9 浏览次数:1
什么是协同(coroutine)?
Lua 协同程序(coroutine)与线程比较类似:拥有独立的堆栈,独立的局部变量,独立的指令指针,同时又与其它协同程序共享全局变量和其它大部分东西。
协同是非常强大的功能,但是用起来也很复杂。
线程和协同程序区别
协程是编译器级别的,线程是操作系统级别的,在多处理器情况下,多线程程序同时运行多个线程;而协同程序是通过协作来完成,在任一指定时刻只有一个协同程序在运行,并且这个正在运行的协同程序只在必要时才会被挂起。这样Lua的协程就不能利用现在多核技术了。
coroutine优缺点分析
上面对coroutine有个基本的了解,因此大家都会象我一样去想,为什么要用coroutine?先研究下优点
再看缺点,研究coroutine缺点之前,我寻找了一下Lua中为什么实现coroutine的一些说明。在巴西人写的paper Coroutines in Lua(pdf)中解释了几个原因:
以上这些理由都是基于Lua特殊的原因而使用的,并不是很通用的原因。我们也了解到,coroutine实际上是一种古老的设计模式,它在60年代就已经定型,但是现代语言很少有重视这个特性,目前可以举例的有Windows的fibers, Python的generators
基本语法:
简例:
--定义协同函数 (匿名函数) cor = coroutine.create( function(a,b) print(a+b) coroutine.yield() --挂起 print(a-b) end ) --调用协同函数,,(暂停、继续) res=coroutine.resume(cor,10,20) --接收的参数第一个是是否成功执行,后面的才是协程运行的返回值 print(res) print("Czhenya的协程") --继续运行协程,不需要传递参数,即使传递也只使用第一次传的参数 coroutine.resume(cor) --协程的状态 suspended(挂起,暂停) running(运行) date(死亡,结束) print(coroutine.status(cor)) --协程运行完成后不能再次启动 coroutine.resume(cor) --[[ 输出是 : 30 true Czhenya的协程 -10 dead --]]
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接