lua 嵌入式linux,云风的 BLOG

我们可以在第一个主模块加载时,在 skynet 中也就是 require "skynet" 这里,启动一个调度器的 coroutine 。

这个 coroutine 只用来管理一个数组,数组里全部是业务逻辑的线程。

这个调度器所属的 coroutine 对应的 lua_State 指针,应该记录在 lua vm 的注册表中,保证只到整个 vm 关闭前都活着,那么,接下来我们就可以放心的把它保存在 host 程序中了。

这样,在 host 程序中,除了原有的代表 vm 以及主线程的 L 之外,我们还有一个代表调度器 coroutine 的 cL 。

启动主逻辑的地方,在创建出 vm 后,通常是加载一个主程序文本,然后使用 lua_resume 运行主线程。如果主线程正常运行结束,则之后不再利用主线程 L 做任何事情;但若主线程被挂起,则把它加到调度线程管理的线程列表组里,之后当作普通业务线程去调度。

我们可以同时提供 lua 及 C API 来向这个数组添加新线程(coroutine) ,调度器的职责是永远在空闲的时候尝试 resume 新添加的线程,以及在外部 IO 消息抵达时去唤醒挂起的线程。这个调度过程中,原来的主线程和其它被创建出来的线程并无区别。

而调度器本身的算法并不需要太复杂,也完全没有必要用 host API 去实现,lua 来编写就完全胜任了。

有了这样的多线程机制后,我们可能还需要对 lua 原有的 coroutine 库做一点改造。改造后可以用业务层的 coroutine 和利用 lua coroutine 实现的线程库可以协同工作。这个之前我已经写过一篇 blog 了 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值