Coroution 协程

由于skynet框架的消息处理使用了coroution,所以不可以将lua原本的coroution API直接和skynet服务混用,否则,skynet的阻塞api(见LUAapi)将调用coroution.yield而使得用户写的coroution.resume有不可预期的返回值.并打乱skynet框架本身的处理流程.


通常,你可以使用skynet.fork,skynet.wait,skynet.wakeup在skynet服务中创建用户级线程.

如果你有其它原因想使用coroution,那么可以使用skynet.coroution模块,改模块的API含义和lua原生的coroution基本一致,所以一般可以这样使用.

local coroutine = require "skynet.coroutine"

改模块增加了一个api:skynet.coroutine.thread(co),它返回两个值,第一个是该co是由那个skynet thread间接调用的.如果co就是一个skynet thread ,那么这个值和coroutine.running()一致,却第二个返回值为true,否则第二个返回值为false.这第二个返回值可以用于判断一个co是否是由skynet.coroutine.create 或 skynet.coroutine.wrap创建出来的coroutine.

这里的co默认值为coroutine.running().


限制

如果你没有调用skynet.coroutine.resume 启动一个skynet coroutine而调用了skynet.coroutine.yield的话,会返回错误.


你可以在不同的skynet线程(由skynet.fork创建,或由一条新的外部消息创建出的处理流程)中resume同一个skynet coroutine.但如果该coroutine是由skynet框架(通常是调用了skynet的阻塞API)而不是skynet.coroutine.yield挂起的话,会被视为normal状态,resume出错


注:对于挂起在skynet框架下的coroutine,skynet.coroutine,status会返回"blocked"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值