协同程序与线程类似,都是一条执行序列。协同程序与线程差不多,也就是一条执行序列,拥有自己独立的栈,局部变量和指令指针,同时又与其它协同程序共享全局变量和其它大部分东西。线程与协同程序的主要区别在于,一个具有多线程的程序可以同时运行几个线程,而协同程序却需要彼此协作地运行。就是说,一个具有多个协同程序的程序在任何时刻只能运行一个协同程序,并且正在运行的协同程序只会在其显示地挂起时,它的执行才会暂停。
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()方法的返回值 返回值:运行过程
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()方法的返回值 返回值:运行过程