我是靠谱客的博主 迅速电脑,最近开发中收集的这篇文章主要介绍lua学习笔记---协同程序(coroutine),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

对于协同程序在真正应用中怎么使用还不太明白,先写下它的使用方法供日后研究吧。直接上代码:

co=coroutine.create(
function(a,b)
print(a+b)
coroutine.yield(a*b)
print(a-b)
end
)
data1,data2= coroutine.resume(co,2,3)
print(data1,data2)
coroutine.resume(co)

co1=coroutine.wrap(
function(c,d)
print(c,d)
end
)
co1(1,2)

协同程序的定义:

1.co=coroutine.create(function(...)end)  

2.co1=coroutine.wrap(function(...)end)  

协同程序的挂起

coroutine.yield(...)这里括号内填什么,就是什么返回值,默认第一个返回值是true或者false。代表该协同程序是否执行。获取返回值从第二个值开始。

协同程序的执行

1.coroutine.resume(co,...)              如果是按上面方法1定义的方法,需要通过coroutine.resume来执行

2.co1(...)                                         如果按方法2定义的方法,可以直接通过方法的形式执行

再看下面代码,一个协同程序如果没有被挂起,无法再用resume去执行该行数。

co=coroutine.create(
function(a,b)
return(a+b)
end
)
data1,data2= coroutine.resume(co,2,3)
print(data1,data2)
data1,data2=coroutine.resume(co,2,4)
print(data1,data2)

得到的返回值为

true    5
false    cannot resume dead coroutine

这里看到再次执行这个协同程序时,不会再执行里边的代码。因为当全部执行完一次之后,已经处于dead状态,不会再被执行。这里就涉及到协同程序状态的概念。

获取协同程序的执行状态

coroutine.status(co)

而协同程序的状态有三种:

挂起状态:suspended    当该协同程序没有被执行或未全部执行完时

执行状态:running        当程序正在方法内执行时

终止状态:dead       当全部执行完毕时

一个协同程序中可以有多个yield存在。举例:

co=coroutine.create(
function(a,b)
print(coroutine.status(co))            ---running
coroutine.yield(a+b)
print(a,b)
coroutine.yield(a+b)
print(a-b)
end
)
data1,data2= coroutine.resume(co,2,3)
print(data1,data2)                   ------true,5
print(coroutine.status(co))                     -----suspended
data1,data2=coroutine.resume(co,2,4)
print(data1,data2)                    --------true,5
print(coroutine.status(co))
data1,data2=coroutine.resume(co,2,4)     ------true,nil
print(data1,data2)
print(coroutine.status(co))         ----dead

这里一定要注意的一点是:当第二次再调用该协同程序时,虽然传进去的是2,4,但这里还是以第一次传进来的2,3作为a,b的值进行的运算。所以后面执行的时候,是可以不再传2,4进去的。将打印结果输出:

running
true    5
suspended
2    3
true    5
suspended
-1
true    nil
dead

这里写一个lua菜鸟教程中对于生产者消费者问题,针对协成的应用。

意思就是我作为消费者想要某个产品,我发出这个订单给生产者,生产者做好之后把产品发回来。然后消费者继续去发出下一个订单。再下面这个例子中,生产者不需要知道消费者到底需要做多少个,因为每次做完,我就等你下一个请求。我只需要知道你从多少开始制作就行。

local newProductor

function productor(min)
     local i =min
     while true do
          i = i + 1
          send(i)     -- 将生产的物品发送给消费者
     end
end

function consumer(min,max)
local j=min
     while j<max do
          j = receive(min)     -- 从生产者那里得到物品
          print(j)
     end
end

function receive(min)
     local status, value = coroutine.resume(newProductor,min)
     return value
end

function send(x)
     coroutine.yield(x)     -- x表示需要发送的值,值返回以后,就挂起该协同程序
end

-- 启动程序
newProductor = coroutine.create(productor)
consumer(10,300)

得到的结果就是从10一直输出到了300

有点明白为什么叫协同程序了,就是需要两个程序合作交互完成某个功能。彼此需要等到对方任务完成,再执行自己的任务。而整个任务过程可能有好几个流程,而某一时刻只可能有一个流程在执行,不会同时执行。

最后

以上就是迅速电脑为你收集整理的lua学习笔记---协同程序(coroutine)的全部内容,希望文章能够帮你解决lua学习笔记---协同程序(coroutine)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(58)

评论列表共有 0 条评论

立即
投稿
返回
顶部