Lua学习之coroutine总结

来源:互联网 发布:如何把mac桌面的图标 编辑:程序博客网 时间:2024/04/28 15:49
协同程序与线程类似,都是一条执行序列。协同程序与线程差不多,也就是一条执行序列,拥有自己独立的栈,局部变量和指令指针,同时又与其它协同程序共享全局变量和其它大部分东西。线程与协同程序的主要区别在于,一个具有多线程的程序可以同时运行几个线程,而协同程序却需要彼此协作地运行。就是说,一个具有多个协同程序的程序在任何时刻只能运行一个协同程序,并且正在运行的协同程序只会在其显示地挂起时,它的执行才会暂停。

1.创建协同程序的方法
co=coroutine.create(f)   创建一个协同程序,f函数的代码就是协同程序执行的内容。返回值为一个thread类型的数据

2.协同程序的状态
挂起  协同程序调用coroutine.yield()方法之后
运行  正常运行时
死亡  运行结束后
正常  当A协同程序唤醒B协同程序时,A协同程序处于正常状态
coroutine.status(co) 可以获取co的状态
coroutine.running():返回当前正在运行的协同程序。


3.协同程序之间交换数据(通过yield与resume方法完成)
coroutine.yield([var1,var2,...]):当运行中的协同程序遇到coroutine.yield()方法后会挂起。传入的变长参数为下一个coroutine.resume()函数的返回值。 返回值为上一个coroutine.resume()方法传入的参数。
coroutine.resume(co,[var1,var2,...]):可以使指定的协同程序(co)恢复运行。参数1 co为需要运行的协同程序。 参数2 变长参数,为下一个coroutine.yield()方法的返回值   返回值:运行过程中没有错误会返回true,之后是前一个coroutine.yield()方法传入的参数。如果运行过程中出现错误,就会返回false,加上错误信息。

生产者--消费者的例子:
function receive(producer)local status,value = coroutine.resume(producer)return valueendfunction send(x)coroutine.yield(x)endfunction producer()return coroutine.create(function()for i = 1,100 do send(i)endend)endfunction consumer(producer)while true dolocal value = receive(producer)if value == 100 then break endprint("receive value: "..value)endend

0 0