Lua:使用类似线程的结构进行抢占式(而非协作式)的多任务处理。

我想知道 Lua 是否内置了任何抢占式多任务处理设施。我想在我的多核系统上使用并发线程。

我研究过协程(参见 lua-users.org/wiki/CoroutinesTutorial 和 stackoverflow.com/questions/3107165/there-is-a-type-named-thread-in-lua-does-anyone-know-something-of-this),但它似乎不太适合我的需求。我编写了以下代码:

function foo(ver)
    local iter = 1;
    while true do
        print("foo ver="..ver.." iter="..iter);
        iter = iter + 1;
        for ii = 1,100000 do end -- busy wait
        coroutine.yield()
     end
end
co1 = coroutine.create(foo)
co2 = coroutine.create(foo)
coroutine.resume(co1, 1)
coroutine.resume(co2, 2)
while true do end -- infinite loop

程序打印:

foo ver=1 iter=1
foo ver=2 iter=1

然后卡住了。我怀疑它只是在无限循环中等待。使用 gdb 连接它会显示只有一个线程正在运行。

我怀疑协程是协作式多任务处理,对吧?

如果是这样,那么有没有一种本地的,Lua 的方式来在 Lua 中使用线程?

如果不是,我必须使用其他库(例如 www.inf.puc-rio.br/~roberto/docs/ry08-05.pdf [PDF] 或 kotisivu.dnainternet.net/askok/bin/lanes/)吗?

谢谢, Tony

原文链接 https://stackoverflow.com/questions/5408371

点赞
stackoverflow用户222481
stackoverflow用户222481

协程确实是协作式的,正如Lua手册所述,而ANSI C不涉及线程,所以在Lua中,就像在C中一样,没有原生的抢占式多线程处理方式。相反,您必须依靠调用底层操作系统。 Lua维基讨论了两种维护线程状态的方法。我还发现了一篇关于协程的博客文章,其中详细介绍了这两种方法的其中一种(尽管他本人并没有涉及到抢占式线程)。

值得注意的是,Lua的书中也提到:“我们认为多线程对于Lua而言不是一个好主意。” 如果您感兴趣,可以在第30章中了解更多关于他们担忧的内容。

2011-03-23 16:44:12
stackoverflow用户513763
stackoverflow用户513763

你可能会对LuaLanes感兴趣,它可以为Lua提供真正的多线程支持。

2011-03-24 08:40:06